All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Gary White (Network Administrator)" <admin@netpathway.com>
To: Petr Vandrovec <vandrove@vc.cvut.cz>
Cc: linux-kernel@vger.kernel.org
Subject: Re: VMWare crashes
Date: Mon, 09 Jul 2001 15:26:55 -0500	[thread overview]
Message-ID: <3B4A138F.EA586C67@netpathway.com> (raw)
In-Reply-To: <82677BD2F89@vcnet.vc.cvut.cz> <3B4A0133.D7270B6D@netpathway.com> <20010709221247.A4040@vana.vc.cvut.cz>

Thanks,

I will apply the patch and see if it cures my problem.

Petr Vandrovec wrote:
> 
> On Mon, Jul 09, 2001 at 02:08:35PM -0500, Gary White (Network Administrator) wrote:
> > Here are the results of ksymoops...
> >
> > Code;  e1af85e1 <[vmnet]VNetHubCycleDetect+69/7c>   <=====
> >    0:   8b 42 70                  mov    0x70(%edx),%eax   <=====
> 
> Thanks, meanwhile I found simillar report on VMware newsgroups, so there must be
> something really real (it was with example how to reproduce it, so I received
> fine oops too).
> 
> Following patch fixes oopses, at least for me. Due to some changes in tasklets
> and/or in networking there is now very large quantum of skbs in flight from
> one part of vmnet (packet written to /dev/vmnet*) through netif_rx to another
> (packet received on eth0 interface). This trigerred 'history buffer overflow'
> message, which then started cleaning history buffer. And if two CPUs started
> cleaning at the same moment, one of them did kfree_skb(NULL) sooner or later...
> 
> So only increasing VNET_BRIDGE_HISTORY from 8 to 48 fixes problem, but as
> I do not want oopses, rest of this patch just fixes oopses themselves. If
> you'll apply patch except VNET_BRIDGE_HISTORY line, it will work, but you'll
> get large stream of 'history buffer full' messages when doing TCP transfers
> between guest and host. (48 is apparently enough for dual PIII/800, I did
> not tested lower values (48 is next multiple of 8 which ends on 8,
> this saved one keystroke and so on...))
> 
> For those unfamiliar with patch (I'm sure there are no on linux-kernel,
> but there can be some in VMware newsgroups) I put updated vmnet.tar.gz
> at ftp://platan.vc.cvut.cz/pub/vmware/vmnet-204-for-2.4.6.tar.gz
> 
>                                         Best regards,
>                                                 Petr Vandrovec
>                                                 vandrove@vc.cvut.cz
> 
> diff -urN vmnet-only.orig/bridge.c vmnet-only/bridge.c
> --- vmnet-only.orig/bridge.c    Thu Apr 26 19:59:28 2001
> +++ vmnet-only/bridge.c Mon Jul  9 21:50:36 2001
> @@ -44,7 +44,7 @@
>  #include "vnetInt.h"
> 
> 
> -#define VNET_BRIDGE_HISTORY    8
> +#define VNET_BRIDGE_HISTORY    48
> 
>  typedef struct VNetBridge VNetBridge;
> 
> @@ -58,6 +58,7 @@
>     Bool                     savedPromisc;
>     struct sk_buff          *history[VNET_BRIDGE_HISTORY];
>     VNetPort                 port;
> +   spinlock_t              historyLock;
>  };
> 
> 
> @@ -130,6 +131,7 @@
>        goto out;
>     }
>     memset(bridge, 0, sizeof *bridge);
> +   spin_lock_init(&bridge->historyLock);
>     memcpy(bridge->name, devName, sizeof bridge->name);
> 
>     /*
> @@ -391,6 +393,8 @@
>          unsigned long flags;
>          int i;
>          SKB_INCREF(clone);
> +
> +        spin_lock_irqsave(&bridge->historyLock, flags);
>          // XXX need to lock history
>          for (i = 0; i < VNET_BRIDGE_HISTORY; i++) {
>             if (bridge->history[i] == NULL) {
> @@ -417,11 +421,15 @@
>             for (i = 0; i < VNET_BRIDGE_HISTORY; i++) {
>                struct sk_buff *s = bridge->history[i];
>                bridge->history[i] = NULL;
> -              KFREE_SKB(s, FREE_WRITE);
> +              if (s) {
> +                 spin_unlock_irqrestore(&bridge->historyLock, flags);
> +                 KFREE_SKB(s, FREE_WRITE);
> +                 spin_lock_irqsave(&bridge->historyLock, flags);
> +              }
>             }
>             bridge->history[0] = clone;
>          }
> -
> +         spin_unlock_irqrestore(&bridge->historyLock, flags);
>          clone->dev = dev;
>          clone->protocol = eth_type_trans(clone, dev);
>          save_flags(flags);
> @@ -773,6 +781,7 @@
>  {
>     VNetBridge *bridge = *(VNetBridge**)&((struct sock *)pt->data)->protinfo;
>     int i;
> +   unsigned long flags;
> 
>     if (bridge->dev == NULL) {
>        LOG(3, (KERN_DEBUG "bridge-%s: received %d closed\n",
> @@ -782,11 +791,13 @@
>     }
> 
>     // XXX need to lock history
> +   spin_lock_irqsave(&bridge->historyLock, flags);
>     for (i = 0; i < VNET_BRIDGE_HISTORY; i++) {
>        struct sk_buff *s = bridge->history[i];
>        if (s != NULL &&
>           (s == skb || SKB_IS_CLONE_OF(skb, s))) {
>          bridge->history[i] = NULL;
> +        spin_unlock_irqrestore(&bridge->historyLock, flags);
>          KFREE_SKB(s, FREE_WRITE);
>          LOG(3, (KERN_DEBUG "bridge-%s: receive %d self %d\n",
>                  bridge->name, (int) skb->len, i));
> @@ -795,6 +806,7 @@
>          return 0;
>        }
>     }
> +   spin_unlock_irqrestore(&bridge->historyLock, flags);
> 
>  #  if LOGLEVEL >= 4
>     {

-- 
Gary White               Network Administrator
admin@netpathway.com          Internet Pathway
Voice 601-776-3355            Fax 601-776-2314


  reply	other threads:[~2001-07-09 20:27 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2001-07-09 18:00 VMWare crashes Petr Vandrovec
2001-07-09 19:08 ` Gary White (Network Administrator)
2001-07-09 20:12   ` Petr Vandrovec
2001-07-09 20:26     ` Gary White (Network Administrator) [this message]
2001-07-09 20:47     ` Gary White (Network Administrator)
2001-07-09 20:21 ` Gary White (Network Administrator)
  -- strict thread matches above, loose matches on Subject: below --
2001-07-09 14:49 Gary White (Network Administrator)
2001-07-09 16:17 ` Mohammad A. Haque

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=3B4A138F.EA586C67@netpathway.com \
    --to=admin@netpathway.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=vandrove@vc.cvut.cz \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.