Skip to main content

vmware net_device trans_start

VMWare Workstation 12 and Kernel 4.7

When recompiling vmware kernel modules on a kernel 4.7, I get this error:

error: ‘struct net_device’ has no member named ‘trans_start’;
did you mean ‘mem_start’?
    dev->trans_start = jiffies;

This seems to be an already encountered problem:
I choosed to replace the line, instead of deleting it.

- dev->trans_start = jiffies;
+ netif_trans_update(dev);

I also noted that I had to re-tar the modified sources instead of leaving them untared, because the compilation process only takes the archives. 

On precedent editions of these files, I just left the modified folders "vmnet-only/" and "vmmon-only/" expanded without the need to re-tar them.


  1. Many thanks. Applied updates and found several things messed up afterward. After taking hours to find the cause of my being unable to logon to the system, and fixing that, I found that (among other things remaining to fix such as regressions in updated code) VMWare Player also was broken again with Linux kernel 4.7. You saved me hours more of time working through that myself.

  2. Thank you for posting that. Would have taken me hours to fix it - maybe I would have ditched vmware instead finally from my system. Great!
    BTW: Since vmware creates a temporary folder to compile that stuff, it's obvious that you have to update the tar file.
    For me "tar uvf /usr/lib/vmware/modules/source/vmnet.tar vmnet-only/netif.c" did the trick.

    J. Gritsch

  3. If you are using Workstation 12.5.2, you need this change instead, in file vmnet-only/compat_netdevice.h:
    - #define compat_netif_trans_update(d) do { (d)->trans_start = jiffies; } while (0)
    + #define compat_netif_trans_update(d) do { netif_trans_update(d); } while (0)

  4. Thank you! I encountered this issue using CENTOS 7, kernel 3.10.0, VMWare Player 7.1.4.

    I applied the fix to netif.c mentioned in this article as follows, just in case there are people who aren't super familiar with the process:

    cd /usr/lib/vmware/modules/source
    tar xvf vmnet.tar

    Open the offending file in the text editor:

    gedit vmnet-only/netif.c

    In the text editor, change line 468 from:

    dev->trans_start = jiffies;



    Repackage the tar file:

    tar cvf vmnet.tar vmnet-only

    Remove the untarred directory:

    rm -fr vmnet-only

    Now restart VMware Player as usual, it should compile.


Post a Comment

Popular posts from this blog

npm run build base-href

Using NPM to specify base-href
When building an Angular application, people usually use "ng" and pass arguments to that invocation.
Typically, when wanting to hard code "base-href" in "index.html", one will issue:

ng build --base-href=''

I used to build my angular apps through Bamboo or Jenkins and they have a "npm" plugin.
I got the habit to build the application with "npm run build" before deploying it.

But the development team once asked me to set the "--base-href=''" parameter.

npm run build --base-href='

did not set the base href in indext.html

After looking for a while, I found where it says:
You need to use −− to pass arguments to npm scripts. This did the job!
The command to issue is then:

npm run build -- --base-href=''

dockerfile multiline to file

Outputing a multiline string from Dockerfile
I motsly use a Dockerfile by sourcing from a base ditribution: CentOS or Debian.
But I also have a local mirror and would like to use it for packages installation.

Espacially on CentOS it is about many lines to write to the /etc/yum.repos.d/CentOS-Base.repo file.

Easiest way: one RUN per line The first method that comes in mind is to issue one RUN per line to write.
Here you are:

RUN echo "[base] " > /etc/yum.repos.d/CentOS-Base.repo RUN echo "name=CentOS-$releasever - Base " >> /etc/yum.repos.d/CentOS-Base.repo RUN echo "baseurl= " >> /etc/yum.repos.d/CentOS-Base.repo RUN echo "gpgcheck=0 " >>…

Project Lead NextGen Project

Jira, change project Lead in a Next-Gent project Atlassian has launched a new feature on Jira Cloud instances: Next-Gent project
Roles, Workflow and settings are not the same as in usual.
When one creates a Next-Gent project, the creator is the "Project Lead", and changin this is not straight:
How-to-change-project-lead-in-a-Next-Gen-ProjectHow-do-i-set-default-assignee-and-workflow-in-next-gen-projects Here is the mergeGet the ID of your project: say 10002Go to https://[account name]!default.jspa?pid=10002Set the project Lead