diff options
author | Benjamin Poirier <bpoirier@suse.de> | 2012-03-08 00:55:58 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-03-08 16:52:08 -0500 |
commit | 0343c5543b1d3ffa08e6716d82afb62648b80eba (patch) | |
tree | 125feb540692bed744e916ff3f12bd14bffdb865 /net/sctp/socket.c | |
parent | b8622cbd58f345d48f683d881abe3037c60aa673 (diff) |
sctp: Export sctp_do_peeloff
lookup sctp_association within sctp_do_peeloff() to enable its use outside of
the sctp code with minimal knowledge of the former.
Signed-off-by: Benjamin Poirier <bpoirier@suse.de>
Acked-by: Vlad Yasevich <vladislav.yasevich@hp.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sctp/socket.c')
-rw-r--r-- | net/sctp/socket.c | 24 |
1 files changed, 9 insertions, 15 deletions
diff --git a/net/sctp/socket.c b/net/sctp/socket.c index 408ebd0e7330..06b42b7f5a02 100644 --- a/net/sctp/socket.c +++ b/net/sctp/socket.c | |||
@@ -4170,14 +4170,16 @@ static int sctp_getsockopt_autoclose(struct sock *sk, int len, char __user *optv | |||
4170 | } | 4170 | } |
4171 | 4171 | ||
4172 | /* Helper routine to branch off an association to a new socket. */ | 4172 | /* Helper routine to branch off an association to a new socket. */ |
4173 | SCTP_STATIC int sctp_do_peeloff(struct sctp_association *asoc, | 4173 | int sctp_do_peeloff(struct sock *sk, sctp_assoc_t id, struct socket **sockp) |
4174 | struct socket **sockp) | ||
4175 | { | 4174 | { |
4176 | struct sock *sk = asoc->base.sk; | 4175 | struct sctp_association *asoc = sctp_id2assoc(sk, id); |
4177 | struct socket *sock; | 4176 | struct socket *sock; |
4178 | struct sctp_af *af; | 4177 | struct sctp_af *af; |
4179 | int err = 0; | 4178 | int err = 0; |
4180 | 4179 | ||
4180 | if (!asoc) | ||
4181 | return -EINVAL; | ||
4182 | |||
4181 | /* An association cannot be branched off from an already peeled-off | 4183 | /* An association cannot be branched off from an already peeled-off |
4182 | * socket, nor is this supported for tcp style sockets. | 4184 | * socket, nor is this supported for tcp style sockets. |
4183 | */ | 4185 | */ |
@@ -4206,13 +4208,13 @@ SCTP_STATIC int sctp_do_peeloff(struct sctp_association *asoc, | |||
4206 | 4208 | ||
4207 | return err; | 4209 | return err; |
4208 | } | 4210 | } |
4211 | EXPORT_SYMBOL(sctp_do_peeloff); | ||
4209 | 4212 | ||
4210 | static int sctp_getsockopt_peeloff(struct sock *sk, int len, char __user *optval, int __user *optlen) | 4213 | static int sctp_getsockopt_peeloff(struct sock *sk, int len, char __user *optval, int __user *optlen) |
4211 | { | 4214 | { |
4212 | sctp_peeloff_arg_t peeloff; | 4215 | sctp_peeloff_arg_t peeloff; |
4213 | struct socket *newsock; | 4216 | struct socket *newsock; |
4214 | int retval = 0; | 4217 | int retval = 0; |
4215 | struct sctp_association *asoc; | ||
4216 | 4218 | ||
4217 | if (len < sizeof(sctp_peeloff_arg_t)) | 4219 | if (len < sizeof(sctp_peeloff_arg_t)) |
4218 | return -EINVAL; | 4220 | return -EINVAL; |
@@ -4220,15 +4222,7 @@ static int sctp_getsockopt_peeloff(struct sock *sk, int len, char __user *optval | |||
4220 | if (copy_from_user(&peeloff, optval, len)) | 4222 | if (copy_from_user(&peeloff, optval, len)) |
4221 | return -EFAULT; | 4223 | return -EFAULT; |
4222 | 4224 | ||
4223 | asoc = sctp_id2assoc(sk, peeloff.associd); | 4225 | retval = sctp_do_peeloff(sk, peeloff.associd, &newsock); |
4224 | if (!asoc) { | ||
4225 | retval = -EINVAL; | ||
4226 | goto out; | ||
4227 | } | ||
4228 | |||
4229 | SCTP_DEBUG_PRINTK("%s: sk: %p asoc: %p\n", __func__, sk, asoc); | ||
4230 | |||
4231 | retval = sctp_do_peeloff(asoc, &newsock); | ||
4232 | if (retval < 0) | 4226 | if (retval < 0) |
4233 | goto out; | 4227 | goto out; |
4234 | 4228 | ||
@@ -4239,8 +4233,8 @@ static int sctp_getsockopt_peeloff(struct sock *sk, int len, char __user *optval | |||
4239 | goto out; | 4233 | goto out; |
4240 | } | 4234 | } |
4241 | 4235 | ||
4242 | SCTP_DEBUG_PRINTK("%s: sk: %p asoc: %p newsk: %p sd: %d\n", | 4236 | SCTP_DEBUG_PRINTK("%s: sk: %p newsk: %p sd: %d\n", |
4243 | __func__, sk, asoc, newsock->sk, retval); | 4237 | __func__, sk, newsock->sk, retval); |
4244 | 4238 | ||
4245 | /* Return the fd mapped to the new socket. */ | 4239 | /* Return the fd mapped to the new socket. */ |
4246 | peeloff.sd = retval; | 4240 | peeloff.sd = retval; |