From 20b4fc248e7dc37934b64f7c04fec386456cf9f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?H=C3=A9ctor=20Louzao?= Date: Wed, 9 Oct 2019 13:18:34 +0200 Subject: [PATCH] How to deal with VMware Issues in Fedora Why this change is needed: based on the fact that we are migrating all howto to quick-docs. --- modules/ROOT/nav.adoc | 9 +- modules/ROOT/pages/how-to-use-vmware.adoc | 102 ++++++++++++++++++++++ 2 files changed, 109 insertions(+), 2 deletions(-) create mode 100644 modules/ROOT/pages/how-to-use-vmware.adoc diff --git a/modules/ROOT/nav.adoc b/modules/ROOT/nav.adoc index 2d4ad15..e651211 100644 --- a/modules/ROOT/nav.adoc +++ b/modules/ROOT/nav.adoc @@ -1,11 +1,14 @@ * xref:howto-file-a-bug.adoc[How to file a bug] + * xref:getting-started-guide.adoc[Getting started with Fedora] + * Installation ** xref:creating-and-using-a-live-installation-image.adoc[Creating and using a live installation image] ** xref:raspberry-pi.adoc[Fedora on Raspberry Pi] + * Usage and customisation ** xref:dnf.adoc[Using the DNF software package manager] ** xref:repositories.adoc[Fedora Repositories] @@ -52,12 +55,11 @@ ** xref:changing-selinux-states-and-modes.adoc[Changing SELinux states and modes] ** xref:troubleshooting_selinux.adoc[Troubleshooting SELinux] + * xref:upgrading.adoc[Upgrading to a new release] ** xref:dnf-system-upgrade.adoc[Upgrading Fedora using the DNF system upgrade] - - * xref:kernel/overview.adoc[Kernel] ** xref:kernel/troubleshooting.adoc[Troubleshooting] ** xref:kernel/build-custom-kernel.adoc[Building a Custom Kernel] @@ -70,6 +72,8 @@ ** xref:qemu.adoc[Using virtualization emulation in QEMU] ** xref:using-nested-virtualization-in-kvm.adoc[Using nested virtualization in KVM] ** xref:creating-windows-virtual-machines-using-virtio-drivers.adoc[Creating Windows virtual machines using virtIO drivers] +** xref:how-to-use-vmware.adoc[How to use Vmware Product's] + //FIXME * xref:autoupdates.adoc[AutoUpdates] //FIXME * xref:debug-dracut-problems.adoc[How to debug Dracut problems] @@ -91,6 +95,7 @@ ** xref:anaconda/anaconda_logging.adoc[Anaconda Logging] ** xref:anaconda/anaconda_product_image.adoc[Anaconda Product Image] + * xref:creating-rpm-packages.adoc[Creating RPM packages] ** xref:create-hello-world-rpm.adoc[Creating a GNU Hello World RPM Package] diff --git a/modules/ROOT/pages/how-to-use-vmware.adoc b/modules/ROOT/pages/how-to-use-vmware.adoc new file mode 100644 index 0000000..891a5c2 --- /dev/null +++ b/modules/ROOT/pages/how-to-use-vmware.adoc @@ -0,0 +1,102 @@ +[id='what-is-VMware'] +== What is *VMware*? + +VMware provides cloud computing and virtualization software and services, their most important product are: + +** VMware Workstation Player, is a virtualization software package and can run existing virtual appliances and create its own virtual machines (which require an operating system to be installed to be functional). VMware Player is available for personal non-commercial use. +** VMware Workstation Pro, it enables users to set up virtual machines (VMs) on a single physical machine, and use them simultaneously along with the actual machine. Each virtual machine can execute its own operating system, including versions of Microsoft Windows, Linux, BSD, and MS-DOS. + +[IMPORTANT] + +You should have a valid license to work with VMware Workstation Pro, this document doesn't provide that function, it's only intent to deal with Vmware issues in Fedora. + +== How to Resolve Issues for VMWORKSTATION and VMPLAYER (ANY KERNEL + ANY VERSION) + +=== Installing *VMware* + +---- +$ sudo ./VMware-Workstation-Full-x.y.z-xx.x86_64.bundle +$ sudo chmod +x ./VMware-Workstation-Full-x.y.z-xx.x86_64.bundle +$ sudo ./VMware-Workstation-Full-x.y.z-xx.x86_64.bundle +---- + +=== Resolving Conflict with Kernel + +The problem here is always the same `vmnet` and `vmmon` doesn’t start well or doesn’t start at all, You should find a PATCH deal with changes in vmmon.c and vmnet.c because something breaks or add some parameters to these files, you can found the following: + +** know what is your kernel version?: `uname -r`. +** know your Vmware version or install the latest. `/usr/bin/vmware -v` +** Try to find the PATCH for a specific KERNEL version and Vmware. +** You have to deal with sources ( **vmnet** and **vmmon** ) and apply fixed in both of them. +** Try to find the fix for the specific product Vmware and Kernel version. + +NOTE: This guide try to help with all this boring stuff. + +=== Prerequisite + +---- +$ sudo dnf install kernel-devel kernel-headers gcc gcc-c++ make git +---- + +=== Installation + +---- +wget https://github.com/mkubecek/vmware-host-modules/archive/workstation-x.y.z.tar.gz +tar -xzf workstation-x.y.z.tar.gz +cd vmware-host-modules-workstation-x.y.z +make +sudo make install +---- + +[IMPORTANT] + +Based on your VMware product, replace “x.y.z” with your installed version and/or “workstation” with “player”. + +=== Deal with Kernel Updates + +You can create a script to take of this after a kernel update. Save it as `/etc/kernel/install.d/99-vmmodules.install`: + +---- + +#!/usr/bin/bash + +export LANG=C + +COMMAND="$1" +KERNEL_VERSION="$2" +BOOT_DIR_ABS="$3" +KERNEL_IMAGE="$4" + +ret=0 + +case "$COMMAND" in + add) + VMWARE_VERSION=$(cat /etc/vmware/config | grep player.product.version | sed '/.*\"\(.*\)\".*/ s//\1/g') + + [ -z VMWARE_VERSION ] && exit 0 + + mkdir -p /tmp/git; cd /tmp/git + git clone -b workstation-${VMWARE_VERSION} https://github.com/mkubecek/vmware-host-modules.git + cd vmware-host-modules + make VM_UNAME=${KERNEL_VERSION} + make install VM_UNAME=${KERNEL_VERSION} + + ((ret+=$?)) + ;; + remove) + exit 0 + ;; + *) + usage + ret=1;; +esac + +exit $ret + +---- + +=== Additional Resources + +- link:https://github.com/mkubecek/vmware-host-modules[VMware Git Repo] + +This repository tracks patches needed to build VMware (Player and Workstation) host modules against recent kernels.