Can you try this patch and test? Regards, Nagalakshmi -----Original Message----- From: Ayman El-Khashab [mailto:ayman@xxxxxxxxxxxxx] Sent: Friday, March 09, 2012 6:25 AM To: Nandigama, Nagalakshmi; linux-scsi@xxxxxxxxxxxxxxx Subject: Re: need help solving mpt2sas target unplug can hang worker thread On Tue, Feb 28, 2012 at 05:18:53PM +0530, Nandigama, Nagalakshmi wrote: > It seems like you are using older version of mpt2sas driver. Current version of mpt2sas driver is 12.100.00.00. Will it be possible to you to test with the latest or any stable driver? Also can you take update the latest firmware? > Ok, I've got now 12.0.0 that I pulled from git. While it compiles clean, I can't get far with it b/c it hangs my system when I insmod the driver. In the past, I have had to apply this patch that I submitted long ago and never got used. * http://lkml.indiana.edu/hypermail/linux/kernel/1107.1/02101.html * Changed the type of chip_phys from a u64 to a phys_addr_t. * Changed ifdef from BITS_PER_LONG to CONFIG_ARCH_DMA_ADDR_T_64BIT so that * it works on 32 bit systems that have pci address spaces larger than 32 * bits. I am doing this on a powerpc 460SX with a sas 2008 part, firmware v 9.0 In any case, it doesn't appear that the I need the #ifdef anymore, but replacing the u64 with phys_addr_t might still be required. After trying to load the code against 2.6.37, the code spins infinately in the loop around line 2613 in the mpt2sas_base.c -- this code specifically. I added prints in the loop, so I observed it never got out of this for loop. It spun until I got this message: ttyS0: 1 input overrun(s) Without any printks it just sits here for ever with this being the last printk reached. printk("chain_depth = %d\n", ioc->chain_depth); for (i = 0; i < ioc->chain_depth; i++) { ioc->chain_lookup[i].chain_buffer = pci_pool_alloc( ioc->chain_dma_pool , GFP_KERNEL, &ioc->chain_lookup[i].chain_buffer_dma); if (!ioc->chain_lookup[i].chain_buffer) { ioc->chain_depth = i; goto chain_done; } total_sz += ioc->request_sz; } Not really sure why it is stuck in this loop and don't know the best way to debug this. Thanks Ayman
Attachment:
chain_lookup_err.patch
Description: chain_lookup_err.patch