>> | > +/* check that SP values are within the ranges defined in RFC 4340 */ >> | > +static u8 dccp_feat_is_valid_sp_val(u8 feat_num, u8 val) >> | > +{ <snip> >> In the CCID-4 subtree, the above statement changes to >> | > + val >= DCCPC_CCID2 && val <= DCCPC_CCID4; >> > > This may cause DCCP client which support only CCID 2 and CCID 3 can not > connect to a DCCP server which support CCID2 to CCID4. > > See as following: > > DCCP client DCCP server > REQUEST -------> > (CHANGE_R/CCID 2 3) > <------- RESPONSE > (CONFIRM_R/CCID 2 2 3 4) > > > RESPONSE from DCCP server with CONFIRM_R(CCID 2 2 3 4) will cause DCCP > client send a reset to DCCP server. > > This is because dccp_feat_confirm_recv() will check whether the feat > list is valid before accept the CCID. > > static u8 dccp_feat_confirm_recv(struct list_head *fn, u8 is_mandatory, > u8 opt, ... { > ... > if (!dccp_feat_sp_list_ok(feat, val, len)) > goto confirmation_failed; > ... > } > Excellent catch, but the problem you point out is not in the range of CCID values. It means that the validity checking for SP values in general is too restrictive: the same problem will reappear not only for CCIDs, but for all SP features that could have values in the Confirm list which may locally be unknown. It is also not what 6.6.8 says: "Note that server-priority features do not have value limitations, since unknown values are handled as a matter of course." So thank you I will restrict the validity check to the confirmed value only. Gerrit -- To unsubscribe from this list: send the line "unsubscribe dccp" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html