Skip to content

Commit

Permalink
vsock: Make transport the proto owner
Browse files Browse the repository at this point in the history
Right now the core vsock module is the owner of the proto family. This
means there's nothing preventing the transport module from unloading if
there are open sockets, which results in a panic. Fix that by allowing
the transport to be the owner, which will refcount it properly.

Includes version bump to 1.0.1.0-k

Passes checkpatch this time, I swear...

Acked-by: Dmitry Torokhov <[email protected]>
Signed-off-by: Andy King <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
  • Loading branch information
Andy King authored and davem330 committed May 5, 2014
1 parent b8dff4e commit 2c4a336
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 26 deletions.
6 changes: 5 additions & 1 deletion include/net/af_vsock.h
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,11 @@ struct vsock_transport {

/**** CORE ****/

int vsock_core_init(const struct vsock_transport *t);
int __vsock_core_init(const struct vsock_transport *t, struct module *owner);
static inline int vsock_core_init(const struct vsock_transport *t)
{
return __vsock_core_init(t, THIS_MODULE);
}
void vsock_core_exit(void);

/**** UTILS ****/
Expand Down
47 changes: 22 additions & 25 deletions net/vmw_vsock/af_vsock.c
Original file line number Diff line number Diff line change
Expand Up @@ -1925,9 +1925,23 @@ static struct miscdevice vsock_device = {
.fops = &vsock_device_ops,
};

static int __vsock_core_init(void)
int __vsock_core_init(const struct vsock_transport *t, struct module *owner)
{
int err;
int err = mutex_lock_interruptible(&vsock_register_mutex);

if (err)
return err;

if (transport) {
err = -EBUSY;
goto err_busy;
}

/* Transport must be the owner of the protocol so that it can't
* unload while there are open sockets.
*/
vsock_proto.owner = owner;
transport = t;

vsock_init_tables();

Expand All @@ -1951,36 +1965,19 @@ static int __vsock_core_init(void)
goto err_unregister_proto;
}

mutex_unlock(&vsock_register_mutex);
return 0;

err_unregister_proto:
proto_unregister(&vsock_proto);
err_misc_deregister:
misc_deregister(&vsock_device);
return err;
}

int vsock_core_init(const struct vsock_transport *t)
{
int retval = mutex_lock_interruptible(&vsock_register_mutex);
if (retval)
return retval;

if (transport) {
retval = -EBUSY;
goto out;
}

transport = t;
retval = __vsock_core_init();
if (retval)
transport = NULL;

out:
transport = NULL;
err_busy:
mutex_unlock(&vsock_register_mutex);
return retval;
return err;
}
EXPORT_SYMBOL_GPL(vsock_core_init);
EXPORT_SYMBOL_GPL(__vsock_core_init);

void vsock_core_exit(void)
{
Expand All @@ -2000,5 +1997,5 @@ EXPORT_SYMBOL_GPL(vsock_core_exit);

MODULE_AUTHOR("VMware, Inc.");
MODULE_DESCRIPTION("VMware Virtual Socket Family");
MODULE_VERSION("1.0.0.0-k");
MODULE_VERSION("1.0.1.0-k");
MODULE_LICENSE("GPL v2");

0 comments on commit 2c4a336

Please sign in to comment.