public inbox for linux-scsi@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] mpt: modify mptctl_exit() to call proper deregister functions
@ 2010-03-15  5:48 Kei Tokunaga
  2010-03-17 15:12 ` Desai, Kashyap
  0 siblings, 1 reply; 2+ messages in thread
From: Kei Tokunaga @ 2010-03-15  5:48 UTC (permalink / raw)
  To: Desai Kashyap; +Cc: linux-scsi@vger.kernel.org, Kei Tokunaga

Hi Desai,

This patch fixes some issues of mptctl_exit().

  1) It doesn't call mpt_deregister() for mptctl_taskmgmt_id
     => Insmoding/rmmoding mptctl.ko repeadtedly (up to
        MPT_MAX_PROTOCOL_DRIVERS-1 at most) can eat up all cb_idx,
        and that would cause a lack of MptCallbacks[], MptDriverClass[],
        and MptEvHandlers[].

  2) It doesn't call mpt_event_deregister() for mptctl_id
     => Need to call it.

  3) It calls mpt_reset_deregister() for mptctl_taskmgmt_id
     => This could accidentally deregister an innocent reset handler
        that you don't want to.

This patch also adds a check for mptctl_taskmgmt_id.

This applies to 2.6.34-rc1.

Thanks,
Kei


Signed-off-by: Kei Tokunaga <tokunaga.keiich@jp.fujitsu.com>
---

 linux-2.6.34-rc1-kei/drivers/message/fusion/mptctl.c |   13 ++++++++++++-
 1 file changed, 12 insertions(+), 1 deletion(-)

diff -puN drivers/message/fusion/mptctl.c~fix-mptctl_exit drivers/message/fusion/mptctl.c
--- linux-2.6.34-rc1/drivers/message/fusion/mptctl.c~fix-mptctl_exit	2010-03-15 09:40:43.000000000 +0900
+++ linux-2.6.34-rc1-kei/drivers/message/fusion/mptctl.c	2010-03-15 09:40:43.000000000 +0900
@@ -2991,6 +2991,14 @@ static int __init mptctl_init(void)
 	}
 
 	mptctl_taskmgmt_id = mpt_register(mptctl_taskmgmt_reply, MPTCTL_DRIVER);
+	if (!mptctl_taskmgmt_id || mptctl_taskmgmt_id >= MPT_MAX_PROTOCOL_DRIVERS) {
+		printk(KERN_ERR MYNAM ": ERROR: Failed to register with Fusion MPT base driver\n");
+		mpt_deregister(mptctl_id);
+		misc_deregister(&mptctl_miscdev);
+		err = -EBUSY;
+		goto out_fail;
+	}
+
 	mpt_reset_register(mptctl_id, mptctl_ioc_reset);
 	mpt_event_register(mptctl_id, mptctl_event_process);
 
@@ -3010,12 +3018,15 @@ static void mptctl_exit(void)
 	printk(KERN_INFO MYNAM ": Deregistered /dev/%s @ (major,minor=%d,%d)\n",
 			 mptctl_miscdev.name, MISC_MAJOR, mptctl_miscdev.minor);
 
+	/* De-register event handler from base module */
+	mpt_event_deregister(mptctl_id);
+
 	/* De-register reset handler from base module */
 	mpt_reset_deregister(mptctl_id);
 
 	/* De-register callback handler from base module */
+	mpt_deregister(mptctl_taskmgmt_id);
 	mpt_deregister(mptctl_id);
-	mpt_reset_deregister(mptctl_taskmgmt_id);
 
         mpt_device_driver_deregister(MPTCTL_DRIVER);
 

_




^ permalink raw reply	[flat|nested] 2+ messages in thread

* RE: [PATCH] mpt: modify mptctl_exit() to call proper deregister functions
  2010-03-15  5:48 [PATCH] mpt: modify mptctl_exit() to call proper deregister functions Kei Tokunaga
@ 2010-03-17 15:12 ` Desai, Kashyap
  0 siblings, 0 replies; 2+ messages in thread
From: Desai, Kashyap @ 2010-03-17 15:12 UTC (permalink / raw)
  To: Kei Tokunaga; +Cc: linux-scsi@vger.kernel.org

Kei,

I do agree, your patch looks fine to me. We can consider if for upstream acceptance.
Please consider this patch as an ACKed.

--Kashyap

> -----Original Message-----
> From: Kei Tokunaga [mailto:tokunaga.keiich@jp.fujitsu.com]
> Sent: Monday, March 15, 2010 11:19 AM
> To: Desai, Kashyap
> Cc: linux-scsi@vger.kernel.org; Kei Tokunaga
> Subject: [PATCH] mpt: modify mptctl_exit() to call proper deregister
> functions
> 
> Hi Desai,
> 
> This patch fixes some issues of mptctl_exit().
> 
>   1) It doesn't call mpt_deregister() for mptctl_taskmgmt_id
>      => Insmoding/rmmoding mptctl.ko repeadtedly (up to
>         MPT_MAX_PROTOCOL_DRIVERS-1 at most) can eat up all cb_idx,
>         and that would cause a lack of MptCallbacks[],
> MptDriverClass[],
>         and MptEvHandlers[].
> 
>   2) It doesn't call mpt_event_deregister() for mptctl_id
>      => Need to call it.
> 
>   3) It calls mpt_reset_deregister() for mptctl_taskmgmt_id
>      => This could accidentally deregister an innocent reset handler
>         that you don't want to.
> 
> This patch also adds a check for mptctl_taskmgmt_id.
> 
> This applies to 2.6.34-rc1.
> 
> Thanks,
> Kei
> 
> 
> Signed-off-by: Kei Tokunaga <tokunaga.keiich@jp.fujitsu.com>
> ---
> 
>  linux-2.6.34-rc1-kei/drivers/message/fusion/mptctl.c |   13
> ++++++++++++-
>  1 file changed, 12 insertions(+), 1 deletion(-)
> 
> diff -puN drivers/message/fusion/mptctl.c~fix-mptctl_exit
> drivers/message/fusion/mptctl.c
> --- linux-2.6.34-rc1/drivers/message/fusion/mptctl.c~fix-mptctl_exit
> 	2010-03-15 09:40:43.000000000 +0900
> +++ linux-2.6.34-rc1-kei/drivers/message/fusion/mptctl.c	2010-03-15
> 09:40:43.000000000 +0900
> @@ -2991,6 +2991,14 @@ static int __init mptctl_init(void)
>  	}
> 
>  	mptctl_taskmgmt_id = mpt_register(mptctl_taskmgmt_reply,
> MPTCTL_DRIVER);
> +	if (!mptctl_taskmgmt_id || mptctl_taskmgmt_id >=
> MPT_MAX_PROTOCOL_DRIVERS) {
> +		printk(KERN_ERR MYNAM ": ERROR: Failed to register with
> Fusion MPT base driver\n");
> +		mpt_deregister(mptctl_id);
> +		misc_deregister(&mptctl_miscdev);
> +		err = -EBUSY;
> +		goto out_fail;
> +	}
> +
>  	mpt_reset_register(mptctl_id, mptctl_ioc_reset);
>  	mpt_event_register(mptctl_id, mptctl_event_process);
> 
> @@ -3010,12 +3018,15 @@ static void mptctl_exit(void)
>  	printk(KERN_INFO MYNAM ": Deregistered /dev/%s @
> (major,minor=%d,%d)\n",
>  			 mptctl_miscdev.name, MISC_MAJOR,
> mptctl_miscdev.minor);
> 
> +	/* De-register event handler from base module */
> +	mpt_event_deregister(mptctl_id);
> +
>  	/* De-register reset handler from base module */
>  	mpt_reset_deregister(mptctl_id);
> 
>  	/* De-register callback handler from base module */
> +	mpt_deregister(mptctl_taskmgmt_id);
>  	mpt_deregister(mptctl_id);
> -	mpt_reset_deregister(mptctl_taskmgmt_id);
> 
>          mpt_device_driver_deregister(MPTCTL_DRIVER);
> 
> 
> _
> 
> 


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2010-03-17 15:12 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-03-15  5:48 [PATCH] mpt: modify mptctl_exit() to call proper deregister functions Kei Tokunaga
2010-03-17 15:12 ` Desai, Kashyap

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox