[dm-devel] [2.6.29 PATCH 01/02] dm target: use module refcount directly
Jonathan Brassow
jbrassow at redhat.com
Thu Jan 8 20:50:09 UTC 2009
Reviewed-by: Jonathan Brassow <jbrassow at redhat.com>
brassow
On Jan 7, 2009, at 2:41 PM, Alasdair G Kergon wrote:
> From: Cheng Renquan <crquan at gmail.com>
>
> The tt_internal's 'use' field is superfluous: the module's refcount
> can do
> the work properly. An acceptable side-effect is that this increases
> the
> reference counts reported by 'lsmod'.
>
> Remove the superfluous test when removing a target module.
>
> Signed-off-by: Cheng Renquan <crquan at gmail.com>
> Reviewed-by: Alasdair G Kergon <agk at redhat.com>
> Signed-off-by: Alasdair G Kergon <agk at redhat.com>
> ---
> drivers/md/dm-target.c | 20 +++-----------------
> 1 files changed, 3 insertions(+), 17 deletions(-)
>
> Index: linux-2.6.28/drivers/md/dm-target.c
> ===================================================================
> --- linux-2.6.28.orig/drivers/md/dm-target.c 2009-01-07
> 20:29:57.000000000 +0000
> +++ linux-2.6.28/drivers/md/dm-target.c 2009-01-07
> 20:30:57.000000000 +0000
> @@ -18,7 +18,6 @@ struct tt_internal {
> struct target_type tt;
>
> struct list_head list;
> - long use;
> };
>
> static LIST_HEAD(_targets);
> @@ -44,12 +43,8 @@ static struct tt_internal *get_target_ty
> down_read(&_lock);
>
> ti = __find_target_type(name);
> - if (ti) {
> - if ((ti->use == 0) && !try_module_get(ti->tt.module))
> - ti = NULL;
> - else
> - ti->use++;
> - }
> + if (ti && !try_module_get(ti->tt.module))
> + ti = NULL;
>
> up_read(&_lock);
> return ti;
> @@ -77,10 +72,7 @@ void dm_put_target_type(struct target_ty
> struct tt_internal *ti = (struct tt_internal *) t;
>
> down_read(&_lock);
> - if (--ti->use == 0)
> - module_put(ti->tt.module);
> -
> - BUG_ON(ti->use < 0);
> + module_put(ti->tt.module);
> up_read(&_lock);
>
> return;
> @@ -140,12 +132,6 @@ void dm_unregister_target(struct target_
> BUG();
> }
>
> - if (ti->use) {
> - DMCRIT("Attempt to unregister target still in use: %s",
> - t->name);
> - BUG();
> - }
> -
> list_del(&ti->list);
> kfree(ti);
>
>
> --
> dm-devel mailing list
> dm-devel at redhat.com
> https://www.redhat.com/mailman/listinfo/dm-devel
More information about the dm-devel
mailing list