o net: new module infrastructure for net_proto_family

  
Next batch of changesets will fix the legacy protocols (IPX, LLC, etc).
Tested with LLC and IPX already.
parent ca49321f
...@@ -127,6 +127,8 @@ struct proto_ops { ...@@ -127,6 +127,8 @@ struct proto_ops {
int offset, size_t size, int flags); int offset, size_t size, int flags);
}; };
struct module;
struct net_proto_family { struct net_proto_family {
int family; int family;
int (*create)(struct socket *sock, int protocol); int (*create)(struct socket *sock, int protocol);
...@@ -135,6 +137,7 @@ struct net_proto_family { ...@@ -135,6 +137,7 @@ struct net_proto_family {
short authentication; short authentication;
short encryption; short encryption;
short encrypt_net; short encrypt_net;
struct module *owner;
}; };
struct iovec; struct iovec;
......
...@@ -506,8 +506,13 @@ struct file_operations bad_sock_fops = { ...@@ -506,8 +506,13 @@ struct file_operations bad_sock_fops = {
void sock_release(struct socket *sock) void sock_release(struct socket *sock)
{ {
if (sock->ops) if (sock->ops) {
const int family = sock->ops->family;
sock->ops->release(sock); sock->ops->release(sock);
sock->ops = NULL;
module_put(net_families[family]->owner);
}
if (sock->fasync_list) if (sock->fasync_list)
printk(KERN_ERR "sock_release: fasync list not empty!\n"); printk(KERN_ERR "sock_release: fasync list not empty!\n");
...@@ -1058,11 +1063,12 @@ int sock_create(int family, int type, int protocol, struct socket **res) ...@@ -1058,11 +1063,12 @@ int sock_create(int family, int type, int protocol, struct socket **res)
sock->type = type; sock->type = type;
i = -EBUSY;
if (!try_module_get(net_families[family]->owner))
goto out_release;
if ((i = net_families[family]->create(sock, protocol)) < 0) if ((i = net_families[family]->create(sock, protocol)) < 0)
{ goto out_release;
sock_release(sock);
goto out;
}
*res = sock; *res = sock;
security_socket_post_create(sock, family, type, protocol); security_socket_post_create(sock, family, type, protocol);
...@@ -1070,6 +1076,9 @@ int sock_create(int family, int type, int protocol, struct socket **res) ...@@ -1070,6 +1076,9 @@ int sock_create(int family, int type, int protocol, struct socket **res)
out: out:
net_family_read_unlock(); net_family_read_unlock();
return i; return i;
out_release:
sock_release(sock);
goto out;
} }
asmlinkage long sys_socket(int family, int type, int protocol) asmlinkage long sys_socket(int family, int type, int protocol)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment