diff options
author | Gerrit Renker <gerrit@erg.abdn.ac.uk> | 2008-11-05 02:43:47 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-11-05 02:43:47 -0500 |
commit | 7d43d1a0f2cf535167ec7247f110a1f85cecac43 (patch) | |
tree | 3dc4411cfe27b3ffd0368a65f8ec17dd809157a7 | |
parent | bd012f2e7be9f69a47d240ded0fa491967d9827c (diff) |
dccp: Implement lookup table for feature-negotiation information
A lookup table for feature-negotiation information, extracted from RFC
4340/42, is provided by this patch. All currently known features can
be found in this table, along with their feature location, their
default value, and type.
Signed-off-by: Gerrit Renker <gerrit@erg.abdn.ac.uk>
Acked-by: Ian McDonald <ian.mcdonald@jandi.co.nz>
Acked-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | include/linux/dccp.h | 9 | ||||
-rw-r--r-- | net/dccp/feat.c | 39 |
2 files changed, 44 insertions, 4 deletions
diff --git a/include/linux/dccp.h b/include/linux/dccp.h index 6080449fbec9..3978aff197d9 100644 --- a/include/linux/dccp.h +++ b/include/linux/dccp.h | |||
@@ -176,19 +176,20 @@ enum { | |||
176 | }; | 176 | }; |
177 | 177 | ||
178 | /* DCCP features (RFC 4340 section 6.4) */ | 178 | /* DCCP features (RFC 4340 section 6.4) */ |
179 | enum { | 179 | enum dccp_feature_numbers { |
180 | DCCPF_RESERVED = 0, | 180 | DCCPF_RESERVED = 0, |
181 | DCCPF_CCID = 1, | 181 | DCCPF_CCID = 1, |
182 | DCCPF_SHORT_SEQNOS = 2, /* XXX: not yet implemented */ | 182 | DCCPF_SHORT_SEQNOS = 2, |
183 | DCCPF_SEQUENCE_WINDOW = 3, | 183 | DCCPF_SEQUENCE_WINDOW = 3, |
184 | DCCPF_ECN_INCAPABLE = 4, /* XXX: not yet implemented */ | 184 | DCCPF_ECN_INCAPABLE = 4, |
185 | DCCPF_ACK_RATIO = 5, | 185 | DCCPF_ACK_RATIO = 5, |
186 | DCCPF_SEND_ACK_VECTOR = 6, | 186 | DCCPF_SEND_ACK_VECTOR = 6, |
187 | DCCPF_SEND_NDP_COUNT = 7, | 187 | DCCPF_SEND_NDP_COUNT = 7, |
188 | DCCPF_MIN_CSUM_COVER = 8, | 188 | DCCPF_MIN_CSUM_COVER = 8, |
189 | DCCPF_DATA_CHECKSUM = 9, /* XXX: not yet implemented */ | 189 | DCCPF_DATA_CHECKSUM = 9, |
190 | /* 10-127 reserved */ | 190 | /* 10-127 reserved */ |
191 | DCCPF_MIN_CCID_SPECIFIC = 128, | 191 | DCCPF_MIN_CCID_SPECIFIC = 128, |
192 | DCCPF_SEND_LEV_RATE = 192, /* RFC 4342, sec. 8.4 */ | ||
192 | DCCPF_MAX_CCID_SPECIFIC = 255, | 193 | DCCPF_MAX_CCID_SPECIFIC = 255, |
193 | }; | 194 | }; |
194 | 195 | ||
diff --git a/net/dccp/feat.c b/net/dccp/feat.c index 933a0ecf8d46..45e36fc7943b 100644 --- a/net/dccp/feat.c +++ b/net/dccp/feat.c | |||
@@ -23,6 +23,43 @@ | |||
23 | 23 | ||
24 | #define DCCP_FEAT_SP_NOAGREE (-123) | 24 | #define DCCP_FEAT_SP_NOAGREE (-123) |
25 | 25 | ||
26 | static const struct { | ||
27 | u8 feat_num; /* DCCPF_xxx */ | ||
28 | enum dccp_feat_type rxtx; /* RX or TX */ | ||
29 | enum dccp_feat_type reconciliation; /* SP or NN */ | ||
30 | u8 default_value; /* as in 6.4 */ | ||
31 | /* | ||
32 | * Lookup table for location and type of features (from RFC 4340/4342) | ||
33 | * +--------------------------+----+-----+----+----+---------+-----------+ | ||
34 | * | Feature | Location | Reconc. | Initial | Section | | ||
35 | * | | RX | TX | SP | NN | Value | Reference | | ||
36 | * +--------------------------+----+-----+----+----+---------+-----------+ | ||
37 | * | DCCPF_CCID | | X | X | | 2 | 10 | | ||
38 | * | DCCPF_SHORT_SEQNOS | | X | X | | 0 | 7.6.1 | | ||
39 | * | DCCPF_SEQUENCE_WINDOW | | X | | X | 100 | 7.5.2 | | ||
40 | * | DCCPF_ECN_INCAPABLE | X | | X | | 0 | 12.1 | | ||
41 | * | DCCPF_ACK_RATIO | | X | | X | 2 | 11.3 | | ||
42 | * | DCCPF_SEND_ACK_VECTOR | X | | X | | 0 | 11.5 | | ||
43 | * | DCCPF_SEND_NDP_COUNT | | X | X | | 0 | 7.7.2 | | ||
44 | * | DCCPF_MIN_CSUM_COVER | X | | X | | 0 | 9.2.1 | | ||
45 | * | DCCPF_DATA_CHECKSUM | X | | X | | 0 | 9.3.1 | | ||
46 | * | DCCPF_SEND_LEV_RATE | X | | X | | 0 | 4342/8.4 | | ||
47 | * +--------------------------+----+-----+----+----+---------+-----------+ | ||
48 | */ | ||
49 | } dccp_feat_table[] = { | ||
50 | { DCCPF_CCID, FEAT_AT_TX, FEAT_SP, 2 }, | ||
51 | { DCCPF_SHORT_SEQNOS, FEAT_AT_TX, FEAT_SP, 0 }, | ||
52 | { DCCPF_SEQUENCE_WINDOW, FEAT_AT_TX, FEAT_NN, 100 }, | ||
53 | { DCCPF_ECN_INCAPABLE, FEAT_AT_RX, FEAT_SP, 0 }, | ||
54 | { DCCPF_ACK_RATIO, FEAT_AT_TX, FEAT_NN, 2 }, | ||
55 | { DCCPF_SEND_ACK_VECTOR, FEAT_AT_RX, FEAT_SP, 0 }, | ||
56 | { DCCPF_SEND_NDP_COUNT, FEAT_AT_TX, FEAT_SP, 0 }, | ||
57 | { DCCPF_MIN_CSUM_COVER, FEAT_AT_RX, FEAT_SP, 0 }, | ||
58 | { DCCPF_DATA_CHECKSUM, FEAT_AT_RX, FEAT_SP, 0 }, | ||
59 | { DCCPF_SEND_LEV_RATE, FEAT_AT_RX, FEAT_SP, 0 }, | ||
60 | }; | ||
61 | #define DCCP_FEAT_SUPPORTED_MAX ARRAY_SIZE(dccp_feat_table) | ||
62 | |||
26 | int dccp_feat_change(struct dccp_minisock *dmsk, u8 type, u8 feature, | 63 | int dccp_feat_change(struct dccp_minisock *dmsk, u8 type, u8 feature, |
27 | u8 *val, u8 len, gfp_t gfp) | 64 | u8 *val, u8 len, gfp_t gfp) |
28 | { | 65 | { |
@@ -639,6 +676,8 @@ const char *dccp_feat_name(const u8 feat) | |||
639 | if (feat > DCCPF_DATA_CHECKSUM && feat < DCCPF_MIN_CCID_SPECIFIC) | 676 | if (feat > DCCPF_DATA_CHECKSUM && feat < DCCPF_MIN_CCID_SPECIFIC) |
640 | return feature_names[DCCPF_RESERVED]; | 677 | return feature_names[DCCPF_RESERVED]; |
641 | 678 | ||
679 | if (feat == DCCPF_SEND_LEV_RATE) | ||
680 | return "Send Loss Event Rate"; | ||
642 | if (feat >= DCCPF_MIN_CCID_SPECIFIC) | 681 | if (feat >= DCCPF_MIN_CCID_SPECIFIC) |
643 | return "CCID-specific"; | 682 | return "CCID-specific"; |
644 | 683 | ||