[DCCP]: Call dccp_feat_init more early in dccp_v4_init_sock
authorArnaldo Carvalho de Melo <acme@mandriva.com>
Tue, 21 Mar 2006 03:24:41 +0000 (19:24 -0800)
committerDavid S. Miller <davem@davemloft.net>
Tue, 21 Mar 2006 03:24:41 +0000 (19:24 -0800)
So that dccp_feat_clean doesn't get confused with uninitialized
list_heads.

Noticed when testing with no ccid kernel modules.

Signed-off-by: Arnaldo Carvalho de Melo <acme@mandriva.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/dccp/ipv4.c

index be5ce57b8046ff4e3b1a27adbb920a7f2e753169..f94286e46c42bce5ba1a9e88db87582eb21f4f8c 100644 (file)
@@ -1051,7 +1051,10 @@ int dccp_v4_init_sock(struct sock *sk)
         * setsockopt(CCIDs-I-want/accept). -acme
         */
        if (likely(!dccp_ctl_socket_init)) {
-               int rc;
+               int rc = dccp_feat_init(sk);
+
+               if (rc)
+                       return rc;
 
                if (dp->dccps_options.dccpo_send_ack_vector) {
                        dp->dccps_hc_rx_ackvec = dccp_ackvec_alloc(GFP_KERNEL);
@@ -1075,10 +1078,6 @@ int dccp_v4_init_sock(struct sock *sk)
                        dp->dccps_hc_rx_ccid = dp->dccps_hc_tx_ccid = NULL;
                        return -ENOMEM;
                }
-
-               rc = dccp_feat_init(sk);
-               if (rc)
-                       return rc;
        } else {
                /* control socket doesn't need feat nego */
                INIT_LIST_HEAD(&dp->dccps_options.dccpo_pending);