diff options
author | Allan Stephens <Allan.Stephens@windriver.com> | 2011-02-23 11:44:49 -0500 |
---|---|---|
committer | Paul Gortmaker <paul.gortmaker@windriver.com> | 2011-03-13 16:35:16 -0400 |
commit | a3796f895ff2917aea331a8d40036c73452b2203 (patch) | |
tree | 38487e8b7cc5b66a815966410e8ddcdcd5f44783 | |
parent | aa8472948487432bacbd099b86e313bc16319495 (diff) |
tipc: Add network address mask helper routines
Introduces a pair of helper routines that convert the network address
for a TIPC node into the network address for its cluster or zone.
This is a cosmetic change designed to avoid future errors caused by
the incorrect use of address bitmasks, and does not alter the existing
operation of TIPC.
Signed-off-by: Allan Stephens <Allan.Stephens@windriver.com>
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
-rw-r--r-- | net/tipc/addr.c | 4 | ||||
-rw-r--r-- | net/tipc/addr.h | 17 | ||||
-rw-r--r-- | net/tipc/node.c | 2 |
3 files changed, 16 insertions, 7 deletions
diff --git a/net/tipc/addr.c b/net/tipc/addr.c index 88463d9a6f12..087e399518c1 100644 --- a/net/tipc/addr.c +++ b/net/tipc/addr.c | |||
@@ -81,9 +81,9 @@ int tipc_in_scope(u32 domain, u32 addr) | |||
81 | { | 81 | { |
82 | if (!domain || (domain == addr)) | 82 | if (!domain || (domain == addr)) |
83 | return 1; | 83 | return 1; |
84 | if (domain == (addr & 0xfffff000u)) /* domain <Z.C.0> */ | 84 | if (domain == tipc_cluster_mask(addr)) /* domain <Z.C.0> */ |
85 | return 1; | 85 | return 1; |
86 | if (domain == (addr & 0xff000000u)) /* domain <Z.0.0> */ | 86 | if (domain == tipc_zone_mask(addr)) /* domain <Z.0.0> */ |
87 | return 1; | 87 | return 1; |
88 | return 0; | 88 | return 0; |
89 | } | 89 | } |
diff --git a/net/tipc/addr.h b/net/tipc/addr.h index 2490fadd0caf..8971aba99aea 100644 --- a/net/tipc/addr.h +++ b/net/tipc/addr.h | |||
@@ -37,6 +37,16 @@ | |||
37 | #ifndef _TIPC_ADDR_H | 37 | #ifndef _TIPC_ADDR_H |
38 | #define _TIPC_ADDR_H | 38 | #define _TIPC_ADDR_H |
39 | 39 | ||
40 | static inline u32 tipc_zone_mask(u32 addr) | ||
41 | { | ||
42 | return addr & 0xff000000u; | ||
43 | } | ||
44 | |||
45 | static inline u32 tipc_cluster_mask(u32 addr) | ||
46 | { | ||
47 | return addr & 0xfffff000u; | ||
48 | } | ||
49 | |||
40 | static inline int in_own_cluster(u32 addr) | 50 | static inline int in_own_cluster(u32 addr) |
41 | { | 51 | { |
42 | return !((addr ^ tipc_own_addr) >> 12); | 52 | return !((addr ^ tipc_own_addr) >> 12); |
@@ -49,14 +59,13 @@ static inline int in_own_cluster(u32 addr) | |||
49 | * after a network hop. | 59 | * after a network hop. |
50 | */ | 60 | */ |
51 | 61 | ||
52 | static inline int addr_domain(int sc) | 62 | static inline u32 addr_domain(u32 sc) |
53 | { | 63 | { |
54 | if (likely(sc == TIPC_NODE_SCOPE)) | 64 | if (likely(sc == TIPC_NODE_SCOPE)) |
55 | return tipc_own_addr; | 65 | return tipc_own_addr; |
56 | if (sc == TIPC_CLUSTER_SCOPE) | 66 | if (sc == TIPC_CLUSTER_SCOPE) |
57 | return tipc_addr(tipc_zone(tipc_own_addr), | 67 | return tipc_cluster_mask(tipc_own_addr); |
58 | tipc_cluster(tipc_own_addr), 0); | 68 | return tipc_zone_mask(tipc_own_addr); |
59 | return tipc_addr(tipc_zone(tipc_own_addr), 0, 0); | ||
60 | } | 69 | } |
61 | 70 | ||
62 | int tipc_addr_domain_valid(u32); | 71 | int tipc_addr_domain_valid(u32); |
diff --git a/net/tipc/node.c b/net/tipc/node.c index d040d4754e39..14f98c81d313 100644 --- a/net/tipc/node.c +++ b/net/tipc/node.c | |||
@@ -470,7 +470,7 @@ struct sk_buff *tipc_node_get_links(const void *req_tlv_area, int req_tlv_space) | |||
470 | 470 | ||
471 | /* Add TLV for broadcast link */ | 471 | /* Add TLV for broadcast link */ |
472 | 472 | ||
473 | link_info.dest = htonl(tipc_own_addr & 0xfffff000); | 473 | link_info.dest = htonl(tipc_cluster_mask(tipc_own_addr)); |
474 | link_info.up = htonl(1); | 474 | link_info.up = htonl(1); |
475 | strlcpy(link_info.str, tipc_bclink_name, TIPC_MAX_LINK_NAME); | 475 | strlcpy(link_info.str, tipc_bclink_name, TIPC_MAX_LINK_NAME); |
476 | tipc_cfg_append_tlv(buf, TIPC_TLV_LINK_INFO, &link_info, sizeof(link_info)); | 476 | tipc_cfg_append_tlv(buf, TIPC_TLV_LINK_INFO, &link_info, sizeof(link_info)); |