diff --git a/examples/test.sh b/examples/test.sh index 0f0aed7..c7b533c 100755 --- a/examples/test.sh +++ b/examples/test.sh @@ -36,5 +36,7 @@ sudo insmod providers/bsd/example_bsd_dpusm_provider.ko sudo insmod providers/gpl/example_gpl_dpusm_provider.ko sudo insmod users/need_provider/example_dpusm_need_provider_user.ko +sudo dmesg | tail -n 100 + echo "Success" # clean up will be called diff --git a/include/dpusm/provider.h b/include/dpusm/provider.h index 324ecde..1e1c1fd 100644 --- a/include/dpusm/provider.h +++ b/include/dpusm/provider.h @@ -13,7 +13,6 @@ typedef struct dpusm_provider_handle { struct module *module; dpusm_pc_t capabilities; /* constant set of capabilities */ const dpusm_pf_t *funcs; /* reference to a struct */ - atomic_t refs; /* how many users are holding this provider */ struct list_head list; struct dpusm_provider_handle *self; } dpusm_ph_t; diff --git a/src/provider.c b/src/provider.c index bd68bd3..d117d4e 100644 --- a/src/provider.c +++ b/src/provider.c @@ -227,7 +227,6 @@ dpusmph_init(struct module *module, const dpusm_pf_t *funcs) dpusmph->module = module; dpusmph->funcs = funcs; dpusmph->self = dpusmph; - atomic_set(&dpusmph->refs, 0); } return dpusmph; @@ -301,7 +300,7 @@ dpusm_provider_unregister_handle(dpusm_t *dpusm, dpusm_ph_t **provider) { } int rc = 0; - const int refs = atomic_read(&(*provider)->refs); + const int refs = module_refcount((*provider)->module) - 1; if (refs) { printk("%s: Unregistering provider \"%s\" with %d references remaining.\n", __func__, module_name((*provider)->module), refs); @@ -349,17 +348,21 @@ dpusm_provider_get(dpusm_t *dpusm, const char *name) { read_lock(&dpusm->lock); dpusm_ph_t **provider = find_provider(dpusm, name); if (provider) { + struct module *module = (*provider)->module; + + printk("refcount %d\n", module_refcount(module)); + /* make sure provider can't be unloaded before user */ - if (!try_module_get((*provider)->module)) { + if (!try_module_get(module)) { printk("Error: Could not increment reference count of %s\n", name); return NULL; } - atomic_inc(&(*provider)->refs); + printk("refcount after %d\n", module_refcount(module)); atomic_inc(&dpusm->active); printk("%s: User has been given a handle to \"%s\" (%p) (now %d users).\n", - __func__, name, *provider, atomic_read(&(*provider)->refs)); + __func__, name, *provider, module_refcount(module) - 1); if ((*provider)->funcs->at_connect) { (*provider)->funcs->at_connect(); @@ -384,14 +387,13 @@ dpusm_provider_put(dpusm_t *dpusm, void *handle) { struct module *module = (*provider)->module; - if (!atomic_read(&(*provider)->refs)) { + if (!(module_refcount(module) - 1)) { printk("%s Error: Cannot decrement provider \"%s\" user count already at 0.\n", __func__, module_name(module)); return DPUSM_ERROR; } module_put(module); - atomic_dec(&(*provider)->refs); atomic_dec(&dpusm->active); if ((*provider)->funcs) { /* provider might have been invalidated */ @@ -401,7 +403,7 @@ dpusm_provider_put(dpusm_t *dpusm, void *handle) { } printk("%s: User has returned a handle to \"%s\" (%p) (now %d users).\n", - __func__, module_name(module), *provider, atomic_read(&(*provider)->refs)); + __func__, module_name(module), *provider, module_refcount(module) - 1); return DPUSM_OK; } @@ -422,7 +424,7 @@ void dpusm_provider_invalidate(dpusm_t *dpusm, const char *name) { (*provider)->funcs = NULL; memset(&(*provider)->capabilities, 0, sizeof((*provider)->capabilities)); printk("%s: Provider \"%s\" has been invalidated with %d users active.\n", - __func__, name, atomic_read(&(*provider)->refs)); + __func__, name, module_refcount((*provider)->module) - 1); /* not decrementing module reference count here - provider is still registered */ } else {