Blame view

net/tipc/addr.c 3.68 KB
b97bf3fd8   Per Liden   [TIPC] Initial merge
1
2
  /*
   * net/tipc/addr.c: TIPC address utility routines
c43072852   YOSHIFUJI Hideaki   [NET] TIPC: Fix w...
3
   *
d50ccc2d3   Jon Maloy   tipc: add 128-bit...
4
   * Copyright (c) 2000-2006, 2018, Ericsson AB
f831c963b   Allan Stephens   tipc: Eliminate c...
5
   * Copyright (c) 2004-2005, 2010-2011, Wind River Systems
b97bf3fd8   Per Liden   [TIPC] Initial merge
6
7
   * All rights reserved.
   *
9ea1fd3c1   Per Liden   [TIPC] License he...
8
   * Redistribution and use in source and binary forms, with or without
b97bf3fd8   Per Liden   [TIPC] Initial merge
9
10
   * modification, are permitted provided that the following conditions are met:
   *
9ea1fd3c1   Per Liden   [TIPC] License he...
11
12
13
14
15
16
17
18
   * 1. Redistributions of source code must retain the above copyright
   *    notice, this list of conditions and the following disclaimer.
   * 2. Redistributions in binary form must reproduce the above copyright
   *    notice, this list of conditions and the following disclaimer in the
   *    documentation and/or other materials provided with the distribution.
   * 3. Neither the names of the copyright holders nor the names of its
   *    contributors may be used to endorse or promote products derived from
   *    this software without specific prior written permission.
b97bf3fd8   Per Liden   [TIPC] Initial merge
19
   *
9ea1fd3c1   Per Liden   [TIPC] License he...
20
21
22
23
24
25
26
27
28
29
30
31
32
33
   * Alternatively, this software may be distributed under the terms of the
   * GNU General Public License ("GPL") version 2 as published by the Free
   * Software Foundation.
   *
   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
   * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
   * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
   * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
   * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
   * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
   * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
b97bf3fd8   Per Liden   [TIPC] Initial merge
34
35
   * POSSIBILITY OF SUCH DAMAGE.
   */
8f92df6ad   Allan Stephens   tipc: Remove prot...
36
  #include "addr.h"
347475395   Ying Xue   tipc: make tipc n...
37
  #include "core.h"
b89afb116   Jon Maloy   tipc: allow close...
38
  bool tipc_in_scope(bool legacy_format, u32 domain, u32 addr)
80e0c3306   Allan Stephens   tipc: Reduce foot...
39
40
  {
  	if (!domain || (domain == addr))
b89afb116   Jon Maloy   tipc: allow close...
41
42
43
  		return true;
  	if (!legacy_format)
  		return false;
a3796f895   Allan Stephens   tipc: Add network...
44
  	if (domain == tipc_cluster_mask(addr)) /* domain <Z.C.0> */
b89afb116   Jon Maloy   tipc: allow close...
45
  		return true;
23fd3eace   Jon Maloy   tipc: remove dire...
46
47
  	if (domain == (addr & TIPC_ZONE_CLUSTER_MASK)) /* domain <Z.C.0> */
  		return true;
202636414   Jon Maloy   tipc: remove rest...
48
  	if (domain == (addr & TIPC_ZONE_MASK)) /* domain <Z.0.0> */
b89afb116   Jon Maloy   tipc: allow close...
49
50
  		return true;
  	return false;
80e0c3306   Allan Stephens   tipc: Reduce foot...
51
  }
d50ccc2d3   Jon Maloy   tipc: add 128-bit...
52
53
54
55
56
57
58
  void tipc_set_node_id(struct net *net, u8 *id)
  {
  	struct tipc_net *tn = tipc_net(net);
  	u32 *tmp = (u32 *)id;
  
  	memcpy(tn->node_id, id, NODE_ID_LEN);
  	tipc_nodeid2string(tn->node_id_string, id);
25b0b9c4e   Jon Maloy   tipc: handle coll...
59
  	tn->trial_addr = tmp[0] ^ tmp[1] ^ tmp[2] ^ tmp[3];
d50ccc2d3   Jon Maloy   tipc: add 128-bit...
60
61
62
63
64
65
  	pr_info("Own node identity %s, cluster identity %u
  ",
  		tipc_own_id_string(net), tn->net_id);
  }
  
  void tipc_set_node_addr(struct net *net, u32 addr)
80e0c3306   Allan Stephens   tipc: Reduce foot...
66
  {
d50ccc2d3   Jon Maloy   tipc: add 128-bit...
67
68
69
70
71
72
73
74
  	struct tipc_net *tn = tipc_net(net);
  	u8 node_id[NODE_ID_LEN] = {0,};
  
  	tn->node_addr = addr;
  	if (!tipc_own_id(net)) {
  		sprintf(node_id, "%x", addr);
  		tipc_set_node_id(net, node_id);
  	}
25b0b9c4e   Jon Maloy   tipc: handle coll...
75
  	tn->trial_addr = addr;
8874ecae2   Chris Packham   tipc: initialise ...
76
  	tn->addr_trial_end = jiffies;
d50ccc2d3   Jon Maloy   tipc: add 128-bit...
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
  	pr_info("32-bit node address hash set to %x
  ", addr);
  }
  
  char *tipc_nodeid2string(char *str, u8 *id)
  {
  	int i;
  	u8 c;
  
  	/* Already a string ? */
  	for (i = 0; i < NODE_ID_LEN; i++) {
  		c = id[i];
  		if (c >= '0' && c <= '9')
  			continue;
  		if (c >= 'A' && c <= 'Z')
  			continue;
  		if (c >= 'a' && c <= 'z')
  			continue;
  		if (c == '.')
  			continue;
  		if (c == ':')
  			continue;
  		if (c == '_')
  			continue;
  		if (c == '-')
  			continue;
  		if (c == '@')
  			continue;
  		if (c != 0)
  			break;
  	}
  	if (i == NODE_ID_LEN) {
  		memcpy(str, id, NODE_ID_LEN);
  		str[NODE_ID_LEN] = 0;
  		return str;
  	}
  
  	/* Translate to hex string */
  	for (i = 0; i < NODE_ID_LEN; i++)
  		sprintf(&str[2 * i], "%02x", id[i]);
  
  	/* Strip off trailing zeroes */
  	for (i = NODE_ID_STR_LEN - 2; str[i] == '0'; i--)
  		str[i] = 0;
  
  	return str;
80e0c3306   Allan Stephens   tipc: Reduce foot...
123
  }