1. 10 Feb, 2009 7 commits
    • Shyam_Iyer@Dell.com's avatar
      [SCSI] qla2xxx: fix Kernel Panic with Qlogic 2472 Card. · 7f977ddd
      Shyam_Iyer@Dell.com authored
      Kernel Panic is observed with a Qlogic 2472 Card is plugged into the
      system and the qla2xxx driver is loaded:
      
      QLogic Fibre Channel HBA Driver: 8.02.01.02.11.0-k9
      vendor=8086 device=3410
      qla2xxx 0000:05:00.0: PCI INT A -> GSI 40 (level, low) -> IRQ 40
      qla2xxx 0000:05:00.0: Found an ISP2432, irq 40, iobase
      0xffffc2001091c000
      qla2xxx 0000:05:00.0: Configuring PCI space...
      qla2xxx 0000:05:00.0: setting latency timer to 64
      qla2xxx 0000:05:00.0: Configure NVRAM parameters...
      BUG: unable to handle kernel NULL pointer dereference at
      0000000000000000
      IP: [<ffffffff8036319a>] strncpy+0x5/0x1e
      PGD 7c564067 PUD 78d8c067 PMD 0
      Oops: 0000 [1] SMP
      last sysfs file:
      /sys/devices/pci0000:00/0000:00:1d.1/usb6/6-2/6-2:1.1/input/input4/event
      4/dev
      CPU 1
      Modules linked in: qla2xxx(+) squashfs usb_storage scsi_transport_fc
      scsi_tgt parport_pc parport arc4 ecb crypto_blkcipher acpi_cpufreq fan
      loop nfs nfs_acl lockd sunrpc nls_iso8859_1 nls_cp437 ipv6 af_packet st
      sr_mod ide_disk ide_cd_mod ide_core cdrom usbhid hid ff_memless sg
      sd_mod crc_t10dif uhci_hcd mptsas mptscsih ehci_hcd mptbase
      scsi_transport_sas rtc_cmos rtc_core rtc_lib usbcore scsi_mod thermal
      bnx2 button processor thermal_sys hwmon edd
      Supported: Yes
      Pid: 4415, comm: insmod Not tainted 2.6.27.13-1-default #1
      RIP: 0010:[<ffffffff8036319a>] [<ffffffff8036319a>] strncpy+0x5/0x1e
      RSP: 0018:ffff88007b04fbc0 EFLAGS: 00010202
      RAX: 00000000000000b7 RBX: ffff88007b9641e0 RCX: ffff88007c1b2ad7
      RDX: 000000000000004f RSI: 0000000000000000 RDI: ffff88007c1b2ad7
      RBP: ffff88007c1b0620 R08: 0000000000000010 R09: 0000000100000000
      R10: 0000000000000046 R11: ffffffff803651c6 R12: ffff88007b074000
      R13: ffff88007b964000 R14: ffff88007c1b2ac6 R15: 0000000000000000
      FS: 00007f91a6c366f0(0000) GS:ffff88007dbeee40(0000)
      knlGS:0000000000000000
      CS: 0010 DS: 0000 ES: 0000 CR0: 000000008005003b
      CR2: 0000000000000000 CR3: 000000007bd7c000 CR4: 00000000000006e0
      DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
      DR3: 0000000000000000 DR6: 00000000ffff0ff0 DR7: 0000000000000400
      Process insmod (pid: 4415, threadinfo ffff88007b04e000, task
      ffff880078586180)
      Stack: ffffffffa02d82c4 0000000000002432 ffff88007d385000
      ffff88007c1b0620
      ffff88007c1b0620 ffff88007c1b0000 ffff88007d385000 0000000000002432
      ffffffffa02dcb1e 0000000000002432 ffffc2001091c000 ffff88007c1b0620
      Call Trace:
      [<ffffffffa02d82c4>] qla24xx_nvram_config+0x385/0x6c2 [qla2xxx]
      [<ffffffffa02dcb1e>] qla2x00_initialize_adapter+0x169/0x383 [qla2xxx]
      [<ffffffffa02f2040>] qla2x00_probe_one+0x6bc/0x9c6 [qla2xxx]
      [<ffffffff8037346f>] pci_device_probe+0xb8/0x105
      [<ffffffff803e5a27>] really_probe+0xdd/0x1e5
      [<ffffffff803e5c14>] __driver_attach+0x46/0x6d
      [<ffffffff803e51e1>] bus_for_each_dev+0x44/0x78
      [<ffffffff803e4ac7>] bus_add_driver+0xef/0x235
      [<ffffffff803e5dd8>] driver_register+0xa2/0x11f
      [<ffffffff803736fd>] __pci_register_driver+0x5d/0x90
      [<ffffffffa0308126>] qla2x00_module_init+0x126/0x159 [qla2xxx]
      [<ffffffff80209041>] _stext+0x41/0x110
      [<ffffffff80260abd>] sys_init_module+0xa0/0x1ba
      [<ffffffff8020bfbb>] system_call_fastpath+0x16/0x1b
      [<00007f91a679b76a>] 0x7f91a679b76a
      Code: ff c1 41 39 c0 75 05 45 85 c0 75 bf 41 29 c0 44 89 c0 c3 31 d2 8a
      04 16 88 04 17 48 ff c2 84 c0 75 f3 48 89 f8 c3 48 89 f9 eb 10 <8a> 06
      3c 01 88 01 48 83 de ff 48 ff c1 48 ff ca 48 85 d2 75 eb
      RIP [<ffffffff8036319a>] strncpy+0x5/0x1e
      RSP <ffff88007b04fbc0>
      CR2: 0000000000000000
      ---[ end trace 829d7d78dfafb785 ]---
      
      The attached patch fixes the issue.
      Signed-off-by: default avatarShyam Iyer <shyam_iyer@dell.com>
      Acked-by: default avatarSeokmann Ju <Seokmann.ju@qlogic.com>
      Signed-off-by: default avatarJames Bottomley <James.Bottomley@HansenPartnership.com>
      7f977ddd
    • Brian King's avatar
      [SCSI] ibmvfc: Increase cancel timeout · 14ae6fac
      Brian King authored
      During cancel testing it has been shown that 15 seconds is not
      nearly long enough for the VIOS to respond to a cancel under
      loaded situations. Increasing this timeout to 60 seconds allows
      time for the VIOS to cancel the outstanding commands and prevents
      us from escalating to a full host reset, which can take much longer.
      Signed-off-by: default avatarBrian King <brking@linux.vnet.ibm.com>
      Signed-off-by: default avatarJames Bottomley <James.Bottomley@HansenPartnership.com>
      14ae6fac
    • Brian King's avatar
      [SCSI] ibmvfc: Fix rport relogin · 0883e3b3
      Brian King authored
      The ibmvfc driver has a bug in its SCN handling. If it receives
      an ELS event such asn an N-Port SCN event or an unsolicited PLOGI,
      or any other SCN event which causes ibmvfc_reinit_host to be called,
      it is possible that we will call fc_remote_port_add for a target
      that already has an rport added, which can result in duplicate
      rports getting created for the same targets. Fix this by calling
      fc_remote_port_rolechg in this scenario instead to report any possible
      role change that may have occurred.
      Signed-off-by: default avatarBrian King <brking@linux.vnet.ibm.com>
      Signed-off-by: default avatarJames Bottomley <James.Bottomley@HansenPartnership.com>
      0883e3b3
    • Brian King's avatar
      [SCSI] ibmvfc: Fix command timeout errors · d4b17a20
      Brian King authored
      Currently the ibmvfc driver sets the IBMVFC_CLASS_3_ERR flag
      in the VFC Frame if both the adapter and the device claim support
      for Class 3. However, this bit actually refers to Class 3 Error
      Recovery, which is currently not supported by the VIOS. Setting this
      bit can cause lots of command timeout responses from the VIOS resulting
      in general instability. Fix this by never setting this bit.
      Signed-off-by: default avatarBrian King <brking@linux.vnet.ibm.com>
      Signed-off-by: default avatarJames Bottomley <James.Bottomley@HansenPartnership.com>
      d4b17a20
    • Martin Peschke's avatar
      [SCSI] sg: fix device number in blktrace data · 76e3a19d
      Martin Peschke authored
      Hi,
      
      we have run into an issue with blktrace being started for sg devices.
      Please apply.
      
      Thanks,
      Martin
      
      From: Martin Peschke <mpeschke@linux.vnet.ibm.com>
      
      The device number denoting a generic SCSI devices (sg) in a blktrace
      trace is broken; major and minor are always 0. It looks like
      sdp->device->sdev_gendev.devt is not initialized properly.
      The fix below uses other data to make up a valid device number,
      similar to the way an sg device number is generated for sysfs output.
      Reported-by: default avatarStefan Raspl <raspl@linux.vnet.ibm.com>
      Signed-off-by: default avatarMartin Peschke <mpeschke@linux.vnet.ibm.com>
      Acked-by: default avatarDouglas Gilbert <dgilbert@interlog.com>
      Signed-off-by: default avatarJames Bottomley <James.Bottomley@HansenPartnership.com>
      76e3a19d
    • James Smart's avatar
      [SCSI] scsi_scan: add missing interim SDEV_DEL state if slave_alloc fails · c2f9e49f
      James Smart authored
      We were running i/o and performing a bunch of hba resets in a loop.
      This forces a lot of target removes and then rescans. Since the
      resets are occuring during scan it's causing the scan i/o to timeout,
      invoking error recovery, etc.  We end up getting some nasty crashing
      in scsi_scan.c due to references to old sdevs that are failing
      but had some lingering references that kept them around.
      
      Fix by setting device state to SDEV_DEL if the LLD's slave_alloc
      fails.
      Signed-off-by: default avatarJames Smart <james.smart@emulex.com>
      Signed-off-by: default avatarJames Bottomley <James.Bottomley@HansenPartnership.com>
      c2f9e49f
    • Robert Jennings's avatar
      [SCSI] ibmvscsi: Correct DMA mapping leak · e637d553
      Robert Jennings authored
      The ibmvscsi client driver is not unmapping the SCSI command after
      encountering a DMA mapping error while trying to map an indirect
      scattergather list for the event pool.  This leads to a leak of DMA
      entitlement that could result in the device failing future DMA operations
      in a CMO environment.
      Signed-off-by: default avatarRobert Jennings <rcj@linux.vnet.ibm.com>
      Acked-by: default avatarBrian King <brking@linux.vnet.ibm.com>
      Signed-off-by: default avatarJames Bottomley <James.Bottomley@HansenPartnership.com>
      e637d553
  2. 09 Feb, 2009 33 commits