diff options
author | Andy King <acking@vmware.com> | 2014-05-01 15:20:43 -0700 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-05-05 13:13:50 -0400 |
commit | 2c4a336e0a3e203fab6aa8d8f7bb70a0ad968a6b (patch) | |
tree | 2d53ba2bdafac830dedc783d455e8c937cb8e2e7 /include/net | |
parent | b8dff4e60cbbb8a3382a265797ef8554a6868f39 (diff) | |
download | lwn-2c4a336e0a3e203fab6aa8d8f7bb70a0ad968a6b.tar.gz lwn-2c4a336e0a3e203fab6aa8d8f7bb70a0ad968a6b.zip |
vsock: Make transport the proto owner
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 <dtor@vmware.com>
Signed-off-by: Andy King <acking@vmware.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/net')
-rw-r--r-- | include/net/af_vsock.h | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/include/net/af_vsock.h b/include/net/af_vsock.h index 7d64d3609ec9..428277869400 100644 --- a/include/net/af_vsock.h +++ b/include/net/af_vsock.h @@ -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 ****/ |