From owner-freebsd-scsi@FreeBSD.ORG Wed Jul 23 04:48:36 2014 Return-Path: Delivered-To: freebsd-scsi@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) (using TLSv1 with cipher ADH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 9A191DAE; Wed, 23 Jul 2014 04:48:36 +0000 (UTC) Received: from nargothrond.kdm.org (nargothrond.kdm.org [70.56.43.81]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 3BF542D17; Wed, 23 Jul 2014 04:48:35 +0000 (UTC) Received: from nargothrond.kdm.org (localhost [127.0.0.1]) by nargothrond.kdm.org (8.14.9/8.14.2) with ESMTP id s6N4MxiJ015145; Tue, 22 Jul 2014 22:22:59 -0600 (MDT) (envelope-from ken@nargothrond.kdm.org) Received: (from ken@localhost) by nargothrond.kdm.org (8.14.9/8.14.9/Submit) id s6N4Mw4m015144; Tue, 22 Jul 2014 22:22:58 -0600 (MDT) (envelope-from ken) Date: Tue, 22 Jul 2014 22:22:58 -0600 From: "Kenneth D. Merry" To: bharat singh Subject: Re: QLogic 24xx FC HBAs not working fine with CAM Target Layer Message-ID: <20140723042258.GA15089@nargothrond.kdm.org> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.23 (2014-03-12) Cc: freebsd-scsi@freebsd.org, freebsd-drivers@freebsd.org X-BeenThere: freebsd-scsi@freebsd.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: SCSI subsystem List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 23 Jul 2014 04:48:36 -0000 On Tue, Jul 22, 2014 at 13:06:53 +0530, bharat singh wrote: > Hello, > > I am trying to use a new firmware on a single port FC HBA with freebsd9 > stable, but facing the firmware issue. > > Card came with firmware version 5.5.0 > (isp0: Board Type 2422, Chip Revision 0x3, resident F/W Revision 5.5.0) > > I upgraded the firmware to 5.6.5, and disabled firmware flag by setting > "fwload_disable=YES" flag in /boot/device.hints to retain the newer > firmware. > On subsequent reboots the firmware fails to initialize and throws > isp0: Mailbox Command 'ABOUT FIRMWARE' failed (TIMEOUT) In general, you want to load the ispfw module or compile it into your kernel. The driver was tested with the firmware included in the module, and may not work as well (or at all) with a different version. If you know what changed between the firmware version compiled into the ispfw module and the one you want to run, you can make any necessary driver modifications. > [root@Ctrl4 ~]# ctladm port -l > Port Online Type Name pp vp WWNN WWPN > Speed Vendor > 0 YES IOCTL CTL ioctl 0 0 0 0 > 0 > 1 YES INTERNAL ctl2cam 0 0 0x5000000edac0c700 > 0x5000000edac0c702 0 > 2 YES INTERNAL CTL internal 0 0 0 0 > 0 > > * It's not showing FC port You need to compile your kernel with: options ISP_TARGET_MODE=1 Otherwise you won't get target mode functionality in the isp(4) driver. > 1448 Jul 22 11:05:37 Ctrl4 kernel: isp0: IN mbox 0 = 0x0008 > 1450 Jul 22 11:05:37 Ctrl4 kernel: isp0: RISC2HOST ISR 0x40000101 > 1451 Jul 22 11:05:37 Ctrl4 last message repeated 999 times > 1454 Jul 22 11:05:37 Ctrl4 kernel: isp0: Polled Mailbox Command (0x8) > Timeout (100000us) (started @ isp_reset:1045) > 1456 Jul 22 11:05:37 Ctrl4 kernel: isp0: Mailbox Command 'ABOUT FIRMWARE' > failed (TIMEOUT) > 1458 Jul 22 11:05:37 Ctrl4 kernel: isp0: RISC2HOST ISR 0x40000101 > 1460 Jul 22 11:05:37 Ctrl4 kernel: Trying to mount root from > ufs:/dev/label/root_0 [rw]... > 1462 Jul 22 11:05:37 Ctrl4 kernel: device_attach: isp0 attach returned 6 > 1464 Jul 22 11:05:37 Ctrl4 kernel: isp0: Adapter> port 0x3000-0x30ff mem 0xc1040000-0xc1043fff irq 16 at device 0.0 > on pci 3 > 1465 Jul 22 11:05:37 Ctrl4 kernel: isp0: loaded firmware isp_2400_multi > > from dmesg: > isp0: RISC2HOST ISR 0x40000101 > isp0: Polled Mailbox Command (0x8) Timeout (100000us) (started @ > isp_reset:1045) > isp0: Mailbox Command 'ABOUT FIRMWARE' failed (TIMEOUT) > isp0: RISC2HOST ISR 0x40000101 > device_attach: isp0 attach returned 6 > isp0: port 0x3000-0x30ff mem > 0xc1040000-0xc1043fff irq 16 at device 0.0 on pci3 > isp0: loaded firmware isp_2400_multi > isp0: set PCI latency to 64 > isp0: request/result area @ 0xf700000/0x38000 > isp0: scdma @ 0xf6b9000/0x1000 > isp0: IN mbox 0 = 0x0000 > isp0: RISC2HOST ISR 0x0 > isp0: RISC2HOST ISR 0x40008001 > isp0: OUT mbox 0 = 0x4000 > isp0: IN mbox 0 = 0x0006 > isp0: IN mbox 1 = 0xdead > > The workaround is to enable the firmware flash by setting > "fwload_disable=NO", but that doesn't serves my purpose. > > Is there a way to avoid the issue without a firmware flash on every reboot ? > Moreover i have seen the issue on older firmware 5.5.0 also, as soon I > disable the firmware flash and reboot. If I recall correctly, the firmware that is loaded on boot is loaded into RAM on the card, not flashed. I don't think it affects what is actually flashed onto the board. So that really is what you want to do. Also, just FYI, in past testing with 4Gb Qlogic boards I was limited to 256MB/sec in each direction when I tried them out. I haven't seen the same limitation with the 8Gb boards. It has been a few years since I tried out target mode with a 4Gb board, but keep an eye out for that once you get it running. Ken -- Kenneth Merry ken@FreeBSD.ORG