Re: [PATCH] ibmvscsi: Fix oops when an interrupt is pending during probe

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Acked-by: Brian King <brking@xxxxxxxxxxxxxxxxxx>

On 07/12/2010 11:59 PM, Anton Blanchard wrote:
> 
> A driver needs to be ready to take an interrupt as soon as it registers
> an interrupt handler. I noticed the following oops when testing kdump:
> 
> ipr: IBM Power RAID SCSI Device Driver version: 2.5.0 (February 11, 2010)
> ibmvscsi 30000002: SRP_VERSION: 16.a
> ibmvscsi 30000002: SRP_VERSION: 16.a
> Unable to handle kernel paging request for data at address 0x00000000
> ...
> pc: c000000004085e34: .tasklet_action+0xf4/0x1dc
> ...
> c000000004086fe4 .__do_softirq+0x16c/0x2c0
> c00000000403138c .call_do_softirq+0x14/0x24
> c00000000400ee14 .do_softirq+0xa0/0x104
> c00000000408690c .irq_exit+0x70/0xd0
> c00000000400f190 .do_IRQ+0x214/0x2a8
> c000000004004804 hardware_interrupt_entry+0x1c/0x98
> --- Exception: 501 (Hardware Interrupt) at c00000000400c544 .raw_local_irq_restore+0x48/0x54
> c00000000465d2a8 ._raw_spin_unlock_irqrestore+0x74/0xa0
> c0000000040e7f00 .__setup_irq+0x2ec/0x3f0
> c0000000040e8198 .request_threaded_irq+0x194/0x22c
> c00000000446d854 .rpavscsi_init_crq_queue+0x284/0x3f0
> c00000000446c764 .ibmvscsi_probe+0x688/0x710
> c00000000402903c .vio_bus_probe+0x37c/0x3e4
> c000000004403f10 .driver_probe_device+0xec/0x1b8
> c000000004404088 .__driver_attach+0xac/0xf4
> c000000004403184 .bus_for_each_dev+0x98/0x104
> c000000004403c98 .driver_attach+0x40/0x60
> c0000000044026f0 .bus_add_driver+0x154/0x324
> c0000000044045d0 .driver_register+0xe8/0x1ac
> c00000000402b2a8 .vio_register_driver+0x54/0x74
> c000000004933ea4 .ibmvscsi_module_init+0x80/0xc0
> c000000004009834 .do_one_initcall+0x98/0x1d8
> c0000000049005b4 .kernel_init+0x27c/0x33c
> c000000004031550 .kernel_thread+0x54/0x70
> 
> srp_task needs to be setup before request_irq. The patch below fixes the oops.
> 
> Signed-off-by: Anton Blanchard <anton@xxxxxxxxx>
> ---
> 
> diff --git a/drivers/scsi/ibmvscsi/rpa_vscsi.c b/drivers/scsi/ibmvscsi/rpa_vscsi.c
> index a864ccc..989b9a8 100644
> --- a/drivers/scsi/ibmvscsi/rpa_vscsi.c
> +++ b/drivers/scsi/ibmvscsi/rpa_vscsi.c
> @@ -277,6 +277,12 @@ static int rpavscsi_init_crq_queue(struct crq_queue *queue,
>  		goto reg_crq_failed;
>  	}
> 
> +	queue->cur = 0;
> +	spin_lock_init(&queue->lock);
> +
> +	tasklet_init(&hostdata->srp_task, (void *)rpavscsi_task,
> +		     (unsigned long)hostdata);
> +
>  	if (request_irq(vdev->irq,
>  			rpavscsi_handle_event,
>  			0, "ibmvscsi", (void *)hostdata) != 0) {
> @@ -291,15 +297,10 @@ static int rpavscsi_init_crq_queue(struct crq_queue *queue,
>  		goto req_irq_failed;
>  	}
> 
> -	queue->cur = 0;
> -	spin_lock_init(&queue->lock);
> -
> -	tasklet_init(&hostdata->srp_task, (void *)rpavscsi_task,
> -		     (unsigned long)hostdata);
> -
>  	return retrc;
> 
>        req_irq_failed:
> +	tasklet_kill(&hostdata->srp_task);
>  	do {
>  		rc = plpar_hcall_norets(H_FREE_CRQ, vdev->unit_address);
>  	} while ((rc == H_BUSY) || (H_IS_LONG_BUSY(rc)));


-- 
Brian King
Linux on Power Virtualization
IBM Linux Technology Center


--
To unsubscribe from this list: send the line "unsubscribe linux-scsi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]
  Powered by Linux