From owner-freebsd-net@FreeBSD.ORG Mon Apr 15 23:17:55 2013 Return-Path: Delivered-To: freebsd-net@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by hub.freebsd.org (Postfix) with ESMTP id B6DDD99C; Mon, 15 Apr 2013 23:17:55 +0000 (UTC) (envelope-from ambrisko@ambrisko.com) Received: from mail.ambrisko.com (mail.ambrisko.com [70.91.206.90]) by mx1.freebsd.org (Postfix) with ESMTP id 8DFAC1F8E; Mon, 15 Apr 2013 23:17:55 +0000 (UTC) X-Ambrisko-Me: Yes Received: from server2.ambrisko.com (HELO internal.ambrisko.com) ([192.168.1.2]) by ironport.ambrisko.com with ESMTP; 15 Apr 2013 16:20:26 -0700 Received: from ambrisko.com (localhost [127.0.0.1]) by internal.ambrisko.com (8.14.4/8.14.4) with ESMTP id r3FNHmt5098465; Mon, 15 Apr 2013 16:17:48 -0700 (PDT) (envelope-from ambrisko@ambrisko.com) Received: (from ambrisko@localhost) by ambrisko.com (8.14.4/8.14.4/Submit) id r3FNHmfa098464; Mon, 15 Apr 2013 16:17:48 -0700 (PDT) (envelope-from ambrisko) Date: Mon, 15 Apr 2013 16:17:48 -0700 From: Doug Ambrisko To: d@delphij.net Subject: Re: bce(4) on the Dell PE 2950 Message-ID: <20130415231748.GA82230@ambrisko.com> References: <1365800188.1418.29.camel@localhost> <516877F0.9080301@delphij.net> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <516877F0.9080301@delphij.net> User-Agent: Mutt/1.4.2.3i Cc: "freebsd-net@freebsd.org" , davidch@freebsd.org, Sean Bruno X-BeenThere: freebsd-net@freebsd.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: Networking and TCP/IP with FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 15 Apr 2013 23:17:55 -0000 On Fri, Apr 12, 2013 at 02:09:04PM -0700, Xin Li wrote: | (Added David to Cc) | | On 04/12/13 13:56, Sean Bruno wrote: | > A note from clusteradm@freebsd.org | > | > It looks like there is some amount of instability or bugginess in | > some of the Broadcom firmware(management) on the bce(4) chipeset | > shipped on later generations of the Poweredge 2950 from Dell: | > | > bce0: | > | > Specifically, we've seen that newer (9 and higher) have issues with | > the doing initial setup and negotiation and that Dell did indeed | > release newer firmware to fix the issues. This requires a full | > reboot into Linux (probably centos6) to get the update to execute. | | I could be wrong but I *think* that the firmware is loaded on device | initialization, so there may be a chance that the driver can do it | when starting? Additionally, maybe one can leverage the kernel | firmware(9) framework so that the firmware can be more easily updated | by user? What we created at work was a tool to dump the NIC's "firmware" via the BCE_DEBUG and BCE_NVRAM_WRITE_SUPPORT. It's totally unsupported but works well :-) The usage is to flash it via Linux etc, boot FreeBSD then dump the NVRAM contents. Then use a "flashing" tool that first saves the MAC address info, write the new image and then restore the MAC address ... otherwise all of your NICs get the same MAC addresses! If someone wants to make a decent tool out of it let me know. It's hacky but works. This is why we added the BCE_NVRAM_WRITE_SUPPORT. This means you need these options enabled in the kernel. It's trivial code based on public data. I tossed it up at: http://www.ambrisko.com/doug/bce_firmware.c It needs a correct usage :-) -r reads the NVRAM and -w writes it. There is no error checking "flashing" the firmware since it isn't done via the chip so if you write trash, then you break your NIC. It's a starting point. I put a header file up at: http://www.ambrisko.com/doug/bce_struct.h We've had issues with bce(4) devices since day one in which the BIOS, BMC and NIC firmware had to be in some type of sync. or things break. For a while we actually had to use a cobbled together NIC firmware image from a couple of releases of firmware. Doug A.