On Thu, 2008-02-21 at 11:17 +0100, Johannes Berg wrote:This removes the __pure from print_mac, so reject as appropriate... Add some type safety to print_mac by using struct print_mac_buf * instead of char *. Signed-off-by: Joe Perches <joe@perches.com> diff --git a/include/linux/if_ether.h b/include/linux/if_ether.h index 42dc6a3..2f8df76 100644 --- a/include/linux/if_ether.h +++ b/include/linux/if_ether.h @@ -129,9 +129,16 @@ extern ssize_t sysfs_format_mac(char *buf, const unsigned char *addr, int len); /* * Display a 6 byte device address (MAC) in a readable format. */ -extern __pure char *print_mac(char *buf, const unsigned char *addr); -#define MAC_BUF_SIZE 18 -#define DECLARE_MAC_BUF(var) char var[MAC_BUF_SIZE] __maybe_unused + +struct print_mac_buf { + char formatted_mac_addr[18]; +}; + +#define DECLARE_MAC_BUF(var) \ + struct print_mac_buf __maybe_unused _##var; \ + struct print_mac_buf __maybe_unused *var = &_##var + +extern char *print_mac(struct print_mac_buf *buf, const unsigned char *addr); #endif diff --git a/net/ethernet/eth.c b/net/ethernet/eth.c index a7b4175..ce607ab 100644 --- a/net/ethernet/eth.c +++ b/net/ethernet/eth.c @@ -384,9 +384,10 @@ ssize_t sysfs_format_mac(char *buf, const unsigned char *addr, int len) } EXPORT_SYMBOL(sysfs_format_mac); -char *print_mac(char *buf, const unsigned char *addr) +char *print_mac(struct print_mac_buf *buf, const unsigned char *addr) { - _format_mac_addr(buf, MAC_BUF_SIZE, addr, ETH_ALEN); - return buf; + _format_mac_addr(buf->formatted_mac_addr, + sizeof(buf->formatted_mac_addr), addr, ETH_ALEN); + return buf->formatted_mac_addr; } EXPORT_SYMBOL(print_mac); -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
| Tarkan Erimer | Re: Dual-Licensing Linux Kernel with GPL V2 and GPL V3 |
| Greg KH | [GIT PATCH] driver core patches against 2.6.24 |
| David Miller | Slow DOWN, please!!! |
| Peter Zijlstra | [PATCH 00/23] per device dirty throttling -v8 |
| Gerrit Renker | [PATCH 27/37] dccp: Integration of dynamic feature activation - part 2 (server side) |
| Jarek Poplawski | [PATCH] pkt_sched: Destroy gen estimators under rtnl_lock(). |
| David Miller | [GIT]: Networking |
| Natalie Protasevich | [BUG] New Kernel Bugs |
git: | |
