diff options
Diffstat (limited to 'net/tipc/eth_media.c')
| -rw-r--r-- | net/tipc/eth_media.c | 39 |
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 | */ |
| 80 | static void eth_media_addr_set(struct tipc_media_addr *a, char *mac) | 80 | static 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 | */ | ||
| 307 | static 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 | */ |
| 326 | static int eth_addr2msg(struct tipc_media_addr *a, char *msg_area) | 313 | static 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 | */ |
| 337 | static int eth_msg2addr(struct tipc_media_addr *a, char *msg_area) | 324 | static 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, |
