sock: Introduce named constants for sk_reuse
authorPavel Emelyanov <xemul@parallels.com>
Thu, 19 Apr 2012 03:39:36 +0000 (03:39 +0000)
committerDavid S. Miller <davem@davemloft.net>
Sat, 21 Apr 2012 19:52:25 +0000 (15:52 -0400)
Name them in a "backward compatible" manner, i.e. reuse or not
are still 1 and 0 respectively. The reuse value of 2 means that
the socket with it will forcibly reuse everyone else's port.

Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
13 files changed:
drivers/block/drbd/drbd_receiver.c
drivers/scsi/iscsi_tcp.c
drivers/staging/ramster/cluster/tcp.c
fs/ocfs2/cluster/tcp.c
include/net/sock.h
net/core/sock.c
net/econet/af_econet.c
net/ipv4/af_inet.c
net/ipv4/inet_connection_sock.c
net/ipv6/af_inet6.c
net/netfilter/ipvs/ip_vs_sync.c
net/rds/tcp_listen.c
net/sunrpc/svcsock.c

index 43beaca53179846f591fc940bb7108a6cc494e3c..436f519bed1c4190168d3f847a9dc692153ca89a 100644 (file)
@@ -664,7 +664,7 @@ static struct socket *drbd_wait_for_connect(struct drbd_conf *mdev)
        timeo = mdev->net_conf->try_connect_int * HZ;
        timeo += (random32() & 1) ? timeo / 7 : -timeo / 7; /* 28.5% random jitter */
 
-       s_listen->sk->sk_reuse    = 1; /* SO_REUSEADDR */
+       s_listen->sk->sk_reuse    = SK_CAN_REUSE; /* SO_REUSEADDR */
        s_listen->sk->sk_rcvtimeo = timeo;
        s_listen->sk->sk_sndtimeo = timeo;
        drbd_setbufsize(s_listen, mdev->net_conf->sndbuf_size,
@@ -841,8 +841,8 @@ retry:
                }
        } while (1);
 
-       msock->sk->sk_reuse = 1; /* SO_REUSEADDR */
-       sock->sk->sk_reuse = 1; /* SO_REUSEADDR */
+       msock->sk->sk_reuse = SK_CAN_REUSE; /* SO_REUSEADDR */
+       sock->sk->sk_reuse = SK_CAN_REUSE; /* SO_REUSEADDR */
 
        sock->sk->sk_allocation = GFP_NOIO;
        msock->sk->sk_allocation = GFP_NOIO;
index 453a740fa68ec80bce8a781b2366792f63cc70c5..922086105b4b27d62e19668448b3fb2282837737 100644 (file)
@@ -662,7 +662,7 @@ iscsi_sw_tcp_conn_bind(struct iscsi_cls_session *cls_session,
 
        /* setup Socket parameters */
        sk = sock->sk;
-       sk->sk_reuse = 1;
+       sk->sk_reuse = SK_CAN_REUSE;
        sk->sk_sndtimeo = 15 * HZ; /* FIXME: make it configurable */
        sk->sk_allocation = GFP_ATOMIC;
 
index 3af1b2c51b7828329728da8e98bc7bc0fb8c19b6..b9721c1055b1688f23ba94013d3d729e345aa4e2 100644 (file)
@@ -2106,7 +2106,7 @@ static int r2net_open_listening_sock(__be32 addr, __be16 port)
        r2net_listen_sock = sock;
        INIT_WORK(&r2net_listen_work, r2net_accept_many);
 
-       sock->sk->sk_reuse = 1;
+       sock->sk->sk_reuse = SK_CAN_REUSE;
        ret = sock->ops->bind(sock, (struct sockaddr *)&sin, sizeof(sin));
        if (ret < 0) {
                printk(KERN_ERR "ramster: Error %d while binding socket at "
index 044e7b58d31c7662a75e29f636cfb86bf2846b67..1bfe8802cc1e231a95b4bca57414d7ef3ed40798 100644 (file)
@@ -2005,7 +2005,7 @@ static int o2net_open_listening_sock(__be32 addr, __be16 port)
        o2net_listen_sock = sock;
        INIT_WORK(&o2net_listen_work, o2net_accept_many);
 
-       sock->sk->sk_reuse = 1;
+       sock->sk->sk_reuse = SK_CAN_REUSE;
        ret = sock->ops->bind(sock, (struct sockaddr *)&sin, sizeof(sin));
        if (ret < 0) {
                printk(KERN_ERR "o2net: Error %d while binding socket at "
index a6ba1f8871fda3077183717a1e099cd5161b555c..4cdb9b3050f4f5b120a69ffa89e5e74d3e93cd28 100644 (file)
@@ -376,6 +376,17 @@ struct sock {
        void                    (*sk_destruct)(struct sock *sk);
 };
 
+/*
+ * SK_CAN_REUSE and SK_NO_REUSE on a socket mean that the socket is OK
+ * or not whether his port will be reused by someone else. SK_FORCE_REUSE
+ * on a socket means that the socket will reuse everybody else's port
+ * without looking at the other's sk_reuse value.
+ */
+
+#define SK_NO_REUSE    0
+#define SK_CAN_REUSE   1
+#define SK_FORCE_REUSE 2
+
 static inline int sk_peek_offset(struct sock *sk, int flags)
 {
        if ((flags & MSG_PEEK) && (sk->sk_peek_off >= 0))
index c7e60eac639bde6a64242760b5fa6418a5abea42..679c5bbe2bed80f836c716412b7d9ceb880917a1 100644 (file)
@@ -561,7 +561,7 @@ int sock_setsockopt(struct socket *sock, int level, int optname,
                        sock_valbool_flag(sk, SOCK_DBG, valbool);
                break;
        case SO_REUSEADDR:
-               sk->sk_reuse = valbool;
+               sk->sk_reuse = (valbool ? SK_CAN_REUSE : SK_NO_REUSE);
                break;
        case SO_TYPE:
        case SO_PROTOCOL:
index 71b5edcee4016948f2075decbdc692d345dfc192..fa14ca76b77b9d55abe999f487d8ff4b42f6a3dc 100644 (file)
@@ -617,7 +617,7 @@ static int econet_create(struct net *net, struct socket *sock, int protocol,
        if (sk == NULL)
                goto out;
 
-       sk->sk_reuse = 1;
+       sk->sk_reuse = SK_CAN_REUSE;
        sock->ops = &econet_ops;
        sock_init_data(sock, sk);
 
@@ -1012,7 +1012,7 @@ static int __init aun_udp_initialise(void)
                return error;
        }
 
-       udpsock->sk->sk_reuse = 1;
+       udpsock->sk->sk_reuse = SK_CAN_REUSE;
        udpsock->sk->sk_allocation = GFP_ATOMIC; /* we're going to call it
                                                    from interrupts */
 
index 3744c1c0af5a1f3c9b082879465c2fa23ef9aa7b..c8f7aee587d1fde87fe136a8733e0e7556c8ec6e 100644 (file)
@@ -350,7 +350,7 @@ lookup_protocol:
        err = 0;
        sk->sk_no_check = answer_no_check;
        if (INET_PROTOSW_REUSE & answer_flags)
-               sk->sk_reuse = 1;
+               sk->sk_reuse = SK_CAN_REUSE;
 
        inet = inet_sk(sk);
        inet->is_icsk = (INET_PROTOSW_ICSK & answer_flags) != 0;
index 7d972f650a61b255b166b6ba262172c12fb2c03f..95e61596e605db31b3212328781fcbd7ea2f8dae 100644 (file)
@@ -182,6 +182,9 @@ have_snum:
        goto tb_not_found;
 tb_found:
        if (!hlist_empty(&tb->owners)) {
+               if (sk->sk_reuse == SK_FORCE_REUSE)
+                       goto success;
+
                if (tb->fastreuse > 0 &&
                    sk->sk_reuse && sk->sk_state != TCP_LISTEN &&
                    smallest_size == -1) {
index 461e7896e5d85562cb19f9e94bb26265f7100bd5..0ad046c7ae95ba25182adf1c347ac09ca622a4f6 100644 (file)
@@ -180,7 +180,7 @@ lookup_protocol:
        err = 0;
        sk->sk_no_check = answer_no_check;
        if (INET_PROTOSW_REUSE & answer_flags)
-               sk->sk_reuse = 1;
+               sk->sk_reuse = SK_CAN_REUSE;
 
        inet = inet_sk(sk);
        inet->is_icsk = (INET_PROTOSW_ICSK & answer_flags) != 0;
index f4e0b6cf82466c711b6c8c484cd9c169b6529add..bf5e538af67b9094c62dca4fad5f82ad1b2dee36 100644 (file)
@@ -1368,7 +1368,7 @@ static struct socket *make_receive_sock(struct net *net)
         */
        sk_change_net(sock->sk, net);
        /* it is equivalent to the REUSEADDR option in user-space */
-       sock->sk->sk_reuse = 1;
+       sock->sk->sk_reuse = SK_CAN_REUSE;
 
        result = sock->ops->bind(sock, (struct sockaddr *) &mcast_addr,
                        sizeof(struct sockaddr));
index 8b5cc4aa8868702cc743a87c96a100e58809865f..72981375f47cc90cba0aaac80952bec3b0636bb4 100644 (file)
@@ -145,7 +145,7 @@ int rds_tcp_listen_init(void)
        if (ret < 0)
                goto out;
 
-       sock->sk->sk_reuse = 1;
+       sock->sk->sk_reuse = SK_CAN_REUSE;
        rds_tcp_nonagle(sock);
 
        write_lock_bh(&sock->sk->sk_callback_lock);
index 824d32fb31214b5f433f439c439e7161fba28fb5..f0132b2e875e40e1a76810e7b8e34a92f39a2a48 100644 (file)
@@ -1556,7 +1556,7 @@ static struct svc_xprt *svc_create_socket(struct svc_serv *serv,
                                        (char *)&val, sizeof(val));
 
        if (type == SOCK_STREAM)
-               sock->sk->sk_reuse = 1;         /* allow address reuse */
+               sock->sk->sk_reuse = SK_CAN_REUSE; /* allow address reuse */
        error = kernel_bind(sock, sin, len);
        if (error < 0)
                goto bummer;