aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv4
diff options
context:
space:
mode:
authorDenis V. Lunev <den@openvz.org>2008-04-03 17:22:32 -0400
committerDavid S. Miller <davem@davemloft.net>2008-04-03 17:22:32 -0400
commit3d58b5fa8e4c461ab09afdacd3d1754fccca06ad (patch)
treeb5793c1cc2f0d41657c5e5d101cc00e07c515a60 /net/ipv4
parent4f049b4f33d07bd11335c3a074ebef14213a3e37 (diff)
[INET]: Rename inet_csk_ctl_sock_create to inet_ctl_sock_create.
This call is nothing common with INET connection sockets code. It simply creates an unhashes kernel sockets for protocol messages. Move the new call into af_inet.c after the rename. Signed-off-by: Denis V. Lunev <den@openvz.org> Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4')
-rw-r--r--net/ipv4/af_inet.c19
-rw-r--r--net/ipv4/inet_connection_sock.c19
-rw-r--r--net/ipv4/tcp_ipv4.c4
3 files changed, 21 insertions, 21 deletions
diff --git a/net/ipv4/af_inet.c b/net/ipv4/af_inet.c
index 5882a1316441..7ab0bd64c9d1 100644
--- a/net/ipv4/af_inet.c
+++ b/net/ipv4/af_inet.c
@@ -1250,6 +1250,25 @@ out:
1250 return segs; 1250 return segs;
1251} 1251}
1252 1252
1253int inet_ctl_sock_create(struct socket **sock, unsigned short family,
1254 unsigned short type, unsigned char protocol)
1255{
1256 int rc = sock_create_kern(family, type, protocol, sock);
1257
1258 if (rc == 0) {
1259 (*sock)->sk->sk_allocation = GFP_ATOMIC;
1260 inet_sk((*sock)->sk)->uc_ttl = -1;
1261 /*
1262 * Unhash it so that IP input processing does not even see it,
1263 * we do not wish this socket to see incoming packets.
1264 */
1265 (*sock)->sk->sk_prot->unhash((*sock)->sk);
1266 }
1267 return rc;
1268}
1269
1270EXPORT_SYMBOL_GPL(inet_ctl_sock_create);
1271
1253unsigned long snmp_fold_field(void *mib[], int offt) 1272unsigned long snmp_fold_field(void *mib[], int offt)
1254{ 1273{
1255 unsigned long res = 0; 1274 unsigned long res = 0;
diff --git a/net/ipv4/inet_connection_sock.c b/net/ipv4/inet_connection_sock.c
index a7fcaf205644..ee55678a987d 100644
--- a/net/ipv4/inet_connection_sock.c
+++ b/net/ipv4/inet_connection_sock.c
@@ -651,25 +651,6 @@ void inet_csk_addr2sockaddr(struct sock *sk, struct sockaddr *uaddr)
651 651
652EXPORT_SYMBOL_GPL(inet_csk_addr2sockaddr); 652EXPORT_SYMBOL_GPL(inet_csk_addr2sockaddr);
653 653
654int inet_csk_ctl_sock_create(struct socket **sock, unsigned short family,
655 unsigned short type, unsigned char protocol)
656{
657 int rc = sock_create_kern(family, type, protocol, sock);
658
659 if (rc == 0) {
660 (*sock)->sk->sk_allocation = GFP_ATOMIC;
661 inet_sk((*sock)->sk)->uc_ttl = -1;
662 /*
663 * Unhash it so that IP input processing does not even see it,
664 * we do not wish this socket to see incoming packets.
665 */
666 (*sock)->sk->sk_prot->unhash((*sock)->sk);
667 }
668 return rc;
669}
670
671EXPORT_SYMBOL_GPL(inet_csk_ctl_sock_create);
672
673#ifdef CONFIG_COMPAT 654#ifdef CONFIG_COMPAT
674int inet_csk_compat_getsockopt(struct sock *sk, int level, int optname, 655int inet_csk_compat_getsockopt(struct sock *sk, int level, int optname,
675 char __user *optval, int __user *optlen) 656 char __user *optval, int __user *optlen)
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c
index 1d77f37d7708..edf5a37bb5c3 100644
--- a/net/ipv4/tcp_ipv4.c
+++ b/net/ipv4/tcp_ipv4.c
@@ -2491,8 +2491,8 @@ struct proto tcp_prot = {
2491void __init tcp_v4_init(void) 2491void __init tcp_v4_init(void)
2492{ 2492{
2493 struct socket *__tcp_socket; 2493 struct socket *__tcp_socket;
2494 if (inet_csk_ctl_sock_create(&__tcp_socket, PF_INET, SOCK_RAW, 2494 if (inet_ctl_sock_create(&__tcp_socket, PF_INET, SOCK_RAW,
2495 IPPROTO_TCP) < 0) 2495 IPPROTO_TCP) < 0)
2496 panic("Failed to create the TCP control socket.\n"); 2496 panic("Failed to create the TCP control socket.\n");
2497 tcp_sock = __tcp_socket->sk; 2497 tcp_sock = __tcp_socket->sk;
2498} 2498}