aboutsummaryrefslogtreecommitdiffstats
path: root/net/tipc/eth_media.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/tipc/eth_media.c')
-rw-r--r--net/tipc/eth_media.c39
1 files changed, 12 insertions, 27 deletions
diff --git a/net/tipc/eth_media.c b/net/tipc/eth_media.c
index 2132c1ef2951..120a676a3360 100644
--- a/net/tipc/eth_media.c
+++ b/net/tipc/eth_media.c
@@ -77,12 +77,13 @@ static struct notifier_block notifier = {
77 * Media-dependent "value" field stores MAC address in first 6 bytes 77 * Media-dependent "value" field stores MAC address in first 6 bytes
78 * and zeroes out the remaining bytes. 78 * and zeroes out the remaining bytes.
79 */ 79 */
80static void eth_media_addr_set(struct tipc_media_addr *a, char *mac) 80static void eth_media_addr_set(const struct tipc_bearer *tb_ptr,
81 struct tipc_media_addr *a, char *mac)
81{ 82{
82 memcpy(a->value, mac, ETH_ALEN); 83 memcpy(a->value, mac, ETH_ALEN);
83 memset(a->value + ETH_ALEN, 0, sizeof(a->value) - ETH_ALEN); 84 memset(a->value + ETH_ALEN, 0, sizeof(a->value) - ETH_ALEN);
84 a->media_id = TIPC_MEDIA_TYPE_ETH; 85 a->media_id = TIPC_MEDIA_TYPE_ETH;
85 a->broadcast = !memcmp(mac, eth_media_info.bcast_addr.value, ETH_ALEN); 86 a->broadcast = !memcmp(mac, tb_ptr->bcast_addr.value, ETH_ALEN);
86} 87}
87 88
88/** 89/**
@@ -110,6 +111,7 @@ static int send_msg(struct sk_buff *buf, struct tipc_bearer *tb_ptr,
110 111
111 skb_reset_network_header(clone); 112 skb_reset_network_header(clone);
112 clone->dev = dev; 113 clone->dev = dev;
114 clone->protocol = htons(ETH_P_TIPC);
113 dev_hard_header(clone, dev, ETH_P_TIPC, dest->value, 115 dev_hard_header(clone, dev, ETH_P_TIPC, dest->value,
114 dev->dev_addr, clone->len); 116 dev->dev_addr, clone->len);
115 dev_queue_xmit(clone); 117 dev_queue_xmit(clone);
@@ -201,9 +203,13 @@ static int enable_bearer(struct tipc_bearer *tb_ptr)
201 /* Associate TIPC bearer with Ethernet bearer */ 203 /* Associate TIPC bearer with Ethernet bearer */
202 eb_ptr->bearer = tb_ptr; 204 eb_ptr->bearer = tb_ptr;
203 tb_ptr->usr_handle = (void *)eb_ptr; 205 tb_ptr->usr_handle = (void *)eb_ptr;
206 memset(tb_ptr->bcast_addr.value, 0, sizeof(tb_ptr->bcast_addr.value));
207 memcpy(tb_ptr->bcast_addr.value, dev->broadcast, ETH_ALEN);
208 tb_ptr->bcast_addr.media_id = TIPC_MEDIA_TYPE_ETH;
209 tb_ptr->bcast_addr.broadcast = 1;
204 tb_ptr->mtu = dev->mtu; 210 tb_ptr->mtu = dev->mtu;
205 tb_ptr->blocked = 0; 211 tb_ptr->blocked = 0;
206 eth_media_addr_set(&tb_ptr->addr, (char *)dev->dev_addr); 212 eth_media_addr_set(tb_ptr, &tb_ptr->addr, (char *)dev->dev_addr);
207 return 0; 213 return 0;
208} 214}
209 215
@@ -302,25 +308,6 @@ static int eth_addr2str(struct tipc_media_addr *a, char *str_buf, int str_size)
302} 308}
303 309
304/** 310/**
305 * eth_str2addr - convert string to Ethernet address
306 */
307static int eth_str2addr(struct tipc_media_addr *a, char *str_buf)
308{
309 char mac[ETH_ALEN];
310 int r;
311
312 r = sscanf(str_buf, "%02x:%02x:%02x:%02x:%02x:%02x",
313 (u32 *)&mac[0], (u32 *)&mac[1], (u32 *)&mac[2],
314 (u32 *)&mac[3], (u32 *)&mac[4], (u32 *)&mac[5]);
315
316 if (r != ETH_ALEN)
317 return 1;
318
319 eth_media_addr_set(a, mac);
320 return 0;
321}
322
323/**
324 * eth_str2addr - convert Ethernet address format to message header format 311 * eth_str2addr - convert Ethernet address format to message header format
325 */ 312 */
326static int eth_addr2msg(struct tipc_media_addr *a, char *msg_area) 313static int eth_addr2msg(struct tipc_media_addr *a, char *msg_area)
@@ -334,12 +321,13 @@ static int eth_addr2msg(struct tipc_media_addr *a, char *msg_area)
334/** 321/**
335 * eth_str2addr - convert message header address format to Ethernet format 322 * eth_str2addr - convert message header address format to Ethernet format
336 */ 323 */
337static int eth_msg2addr(struct tipc_media_addr *a, char *msg_area) 324static int eth_msg2addr(const struct tipc_bearer *tb_ptr,
325 struct tipc_media_addr *a, char *msg_area)
338{ 326{
339 if (msg_area[TIPC_MEDIA_TYPE_OFFSET] != TIPC_MEDIA_TYPE_ETH) 327 if (msg_area[TIPC_MEDIA_TYPE_OFFSET] != TIPC_MEDIA_TYPE_ETH)
340 return 1; 328 return 1;
341 329
342 eth_media_addr_set(a, msg_area + ETH_ADDR_OFFSET); 330 eth_media_addr_set(tb_ptr, a, msg_area + ETH_ADDR_OFFSET);
343 return 0; 331 return 0;
344} 332}
345 333
@@ -351,11 +339,8 @@ static struct tipc_media eth_media_info = {
351 .enable_bearer = enable_bearer, 339 .enable_bearer = enable_bearer,
352 .disable_bearer = disable_bearer, 340 .disable_bearer = disable_bearer,
353 .addr2str = eth_addr2str, 341 .addr2str = eth_addr2str,
354 .str2addr = eth_str2addr,
355 .addr2msg = eth_addr2msg, 342 .addr2msg = eth_addr2msg,
356 .msg2addr = eth_msg2addr, 343 .msg2addr = eth_msg2addr,
357 .bcast_addr = { { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff },
358 TIPC_MEDIA_TYPE_ETH, 1 },
359 .priority = TIPC_DEF_LINK_PRI, 344 .priority = TIPC_DEF_LINK_PRI,
360 .tolerance = TIPC_DEF_LINK_TOL, 345 .tolerance = TIPC_DEF_LINK_TOL,
361 .window = TIPC_DEF_LINK_WIN, 346 .window = TIPC_DEF_LINK_WIN,