diff options
Diffstat (limited to 'net/dccp/ipv6.c')
-rw-r--r-- | net/dccp/ipv6.c | 33 |
1 files changed, 28 insertions, 5 deletions
diff --git a/net/dccp/ipv6.c b/net/dccp/ipv6.c index 19a4f763099d..201801e1532d 100644 --- a/net/dccp/ipv6.c +++ b/net/dccp/ipv6.c | |||
@@ -487,10 +487,10 @@ static int dccp_v6_conn_request(struct sock *sk, struct sk_buff *skb) | |||
487 | /* | 487 | /* |
488 | * Step 3: Process LISTEN state | 488 | * Step 3: Process LISTEN state |
489 | * | 489 | * |
490 | * Set S.ISR, S.GSR, S.SWL, S.SWH from packet or Init Cookie | 490 | * Set S.ISR, S.GSR, S.SWL, S.SWH from packet or Init Cookie |
491 | * | 491 | * |
492 | * In fact we defer setting S.GSR, S.SWL, S.SWH to | 492 | * In fact we defer setting S.GSR, S.SWL, S.SWH to |
493 | * dccp_create_openreq_child. | 493 | * dccp_create_openreq_child. |
494 | */ | 494 | */ |
495 | dreq = dccp_rsk(req); | 495 | dreq = dccp_rsk(req); |
496 | dreq->dreq_isr = dcb->dccpd_seq; | 496 | dreq->dreq_isr = dcb->dccpd_seq; |
@@ -760,6 +760,30 @@ static int dccp_v6_do_rcv(struct sock *sk, struct sk_buff *skb) | |||
760 | return 0; | 760 | return 0; |
761 | } | 761 | } |
762 | 762 | ||
763 | /* | ||
764 | * Step 3: Process LISTEN state | ||
765 | * If S.state == LISTEN, | ||
766 | * If P.type == Request or P contains a valid Init Cookie option, | ||
767 | * (* Must scan the packet's options to check for Init | ||
768 | * Cookies. Only Init Cookies are processed here, | ||
769 | * however; other options are processed in Step 8. This | ||
770 | * scan need only be performed if the endpoint uses Init | ||
771 | * Cookies *) | ||
772 | * (* Generate a new socket and switch to that socket *) | ||
773 | * Set S := new socket for this port pair | ||
774 | * S.state = RESPOND | ||
775 | * Choose S.ISS (initial seqno) or set from Init Cookies | ||
776 | * Initialize S.GAR := S.ISS | ||
777 | * Set S.ISR, S.GSR, S.SWL, S.SWH from packet or Init Cookies | ||
778 | * Continue with S.state == RESPOND | ||
779 | * (* A Response packet will be generated in Step 11 *) | ||
780 | * Otherwise, | ||
781 | * Generate Reset(No Connection) unless P.type == Reset | ||
782 | * Drop packet and return | ||
783 | * | ||
784 | * NOTE: the check for the packet types is done in | ||
785 | * dccp_rcv_state_process | ||
786 | */ | ||
763 | if (sk->sk_state == DCCP_LISTEN) { | 787 | if (sk->sk_state == DCCP_LISTEN) { |
764 | struct sock *nsk = dccp_v6_hnd_req(sk, skb); | 788 | struct sock *nsk = dccp_v6_hnd_req(sk, skb); |
765 | 789 | ||
@@ -826,8 +850,6 @@ static int dccp_v6_rcv(struct sk_buff **pskb) | |||
826 | /* | 850 | /* |
827 | * Step 2: | 851 | * Step 2: |
828 | * If no socket ... | 852 | * If no socket ... |
829 | * Generate Reset(No Connection) unless P.type == Reset | ||
830 | * Drop packet and return | ||
831 | */ | 853 | */ |
832 | if (sk == NULL) { | 854 | if (sk == NULL) { |
833 | dccp_pr_debug("failed to look up flow ID in table and " | 855 | dccp_pr_debug("failed to look up flow ID in table and " |
@@ -857,6 +879,7 @@ no_dccp_socket: | |||
857 | goto discard_it; | 879 | goto discard_it; |
858 | /* | 880 | /* |
859 | * Step 2: | 881 | * Step 2: |
882 | * If no socket ... | ||
860 | * Generate Reset(No Connection) unless P.type == Reset | 883 | * Generate Reset(No Connection) unless P.type == Reset |
861 | * Drop packet and return | 884 | * Drop packet and return |
862 | */ | 885 | */ |