mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 02:36:02 +00:00
sctp: move 198 addresses from unusable to private scope
The doc draft-stewart-tsvwg-sctp-ipv4-00 that restricts 198 addresses was never published. These addresses as private addresses should be allowed to use in SCTP. As Michael Tuexen suggested, this patch is to move 198 addresses from unusable to private scope. Reported-by: Sérgio <surkamp@gmail.com> Signed-off-by: Xin Long <lucien.xin@gmail.com> Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
650b2a846d
commit
1d11fa231c
@ -360,8 +360,7 @@ enum {
|
|||||||
#define SCTP_SCOPE_POLICY_MAX SCTP_SCOPE_POLICY_LINK
|
#define SCTP_SCOPE_POLICY_MAX SCTP_SCOPE_POLICY_LINK
|
||||||
|
|
||||||
/* Based on IPv4 scoping <draft-stewart-tsvwg-sctp-ipv4-00.txt>,
|
/* Based on IPv4 scoping <draft-stewart-tsvwg-sctp-ipv4-00.txt>,
|
||||||
* SCTP IPv4 unusable addresses: 0.0.0.0/8, 224.0.0.0/4, 198.18.0.0/24,
|
* SCTP IPv4 unusable addresses: 0.0.0.0/8, 224.0.0.0/4, 192.88.99.0/24.
|
||||||
* 192.88.99.0/24.
|
|
||||||
* Also, RFC 8.4, non-unicast addresses are not considered valid SCTP
|
* Also, RFC 8.4, non-unicast addresses are not considered valid SCTP
|
||||||
* addresses.
|
* addresses.
|
||||||
*/
|
*/
|
||||||
@ -369,7 +368,6 @@ enum {
|
|||||||
((htonl(INADDR_BROADCAST) == a) || \
|
((htonl(INADDR_BROADCAST) == a) || \
|
||||||
ipv4_is_multicast(a) || \
|
ipv4_is_multicast(a) || \
|
||||||
ipv4_is_zeronet(a) || \
|
ipv4_is_zeronet(a) || \
|
||||||
ipv4_is_test_198(a) || \
|
|
||||||
ipv4_is_anycast_6to4(a))
|
ipv4_is_anycast_6to4(a))
|
||||||
|
|
||||||
/* Flags used for the bind address copy functions. */
|
/* Flags used for the bind address copy functions. */
|
||||||
|
@ -398,7 +398,8 @@ static enum sctp_scope sctp_v4_scope(union sctp_addr *addr)
|
|||||||
retval = SCTP_SCOPE_LINK;
|
retval = SCTP_SCOPE_LINK;
|
||||||
} else if (ipv4_is_private_10(addr->v4.sin_addr.s_addr) ||
|
} else if (ipv4_is_private_10(addr->v4.sin_addr.s_addr) ||
|
||||||
ipv4_is_private_172(addr->v4.sin_addr.s_addr) ||
|
ipv4_is_private_172(addr->v4.sin_addr.s_addr) ||
|
||||||
ipv4_is_private_192(addr->v4.sin_addr.s_addr)) {
|
ipv4_is_private_192(addr->v4.sin_addr.s_addr) ||
|
||||||
|
ipv4_is_test_198(addr->v4.sin_addr.s_addr)) {
|
||||||
retval = SCTP_SCOPE_PRIVATE;
|
retval = SCTP_SCOPE_PRIVATE;
|
||||||
} else {
|
} else {
|
||||||
retval = SCTP_SCOPE_GLOBAL;
|
retval = SCTP_SCOPE_GLOBAL;
|
||||||
|
Loading…
Reference in New Issue
Block a user