diff options
| author | Andy Shevchenko <andy.shevchenko@gmail.com> | 2013-06-04 12:46:26 -0400 |
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2013-06-05 15:00:27 -0400 |
| commit | 4cd5773a2ae6facdde3f563087a4cc50f00d9530 (patch) | |
| tree | f473e0a20e69f056394d3b268bfb4256cedff4ed /lib | |
| parent | 143e9c76c487957de89808cf2a3c828518ad131b (diff) | |
net: core: move mac_pton() to lib/net_utils.c
Since we have at least one user of this function outside of CONFIG_NET
scope, we have to provide this function independently. The proposed
solution is to move it under lib/net_utils.c with corresponding
configuration variable and select wherever it is needed.
Signed-off-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Reported-by: Arnd Bergmann <arnd@arndb.de>
Acked-by: David S. Miller <davem@davemloft.net>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/Kconfig | 3 | ||||
| -rw-r--r-- | lib/Makefile | 2 | ||||
| -rw-r--r-- | lib/net_utils.c | 26 |
3 files changed, 31 insertions, 0 deletions
diff --git a/lib/Kconfig b/lib/Kconfig index fe01d418b09a..d246a3bbd6ef 100644 --- a/lib/Kconfig +++ b/lib/Kconfig | |||
| @@ -22,6 +22,9 @@ config GENERIC_STRNCPY_FROM_USER | |||
| 22 | config GENERIC_STRNLEN_USER | 22 | config GENERIC_STRNLEN_USER |
| 23 | bool | 23 | bool |
| 24 | 24 | ||
| 25 | config GENERIC_NET_UTILS | ||
| 26 | bool | ||
| 27 | |||
| 25 | config GENERIC_FIND_FIRST_BIT | 28 | config GENERIC_FIND_FIRST_BIT |
| 26 | bool | 29 | bool |
| 27 | 30 | ||
diff --git a/lib/Makefile b/lib/Makefile index c55a037a354e..22f0f4e8a9e1 100644 --- a/lib/Makefile +++ b/lib/Makefile | |||
| @@ -137,6 +137,8 @@ obj-$(CONFIG_DDR) += jedec_ddr_data.o | |||
| 137 | obj-$(CONFIG_GENERIC_STRNCPY_FROM_USER) += strncpy_from_user.o | 137 | obj-$(CONFIG_GENERIC_STRNCPY_FROM_USER) += strncpy_from_user.o |
| 138 | obj-$(CONFIG_GENERIC_STRNLEN_USER) += strnlen_user.o | 138 | obj-$(CONFIG_GENERIC_STRNLEN_USER) += strnlen_user.o |
| 139 | 139 | ||
| 140 | obj-$(CONFIG_GENERIC_NET_UTILS) += net_utils.o | ||
| 141 | |||
| 140 | obj-$(CONFIG_STMP_DEVICE) += stmp_device.o | 142 | obj-$(CONFIG_STMP_DEVICE) += stmp_device.o |
| 141 | 143 | ||
| 142 | libfdt_files = fdt.o fdt_ro.o fdt_wip.o fdt_rw.o fdt_sw.o fdt_strerror.o | 144 | libfdt_files = fdt.o fdt_ro.o fdt_wip.o fdt_rw.o fdt_sw.o fdt_strerror.o |
diff --git a/lib/net_utils.c b/lib/net_utils.c new file mode 100644 index 000000000000..2e3c52c8d050 --- /dev/null +++ b/lib/net_utils.c | |||
| @@ -0,0 +1,26 @@ | |||
| 1 | #include <linux/string.h> | ||
| 2 | #include <linux/if_ether.h> | ||
| 3 | #include <linux/ctype.h> | ||
| 4 | #include <linux/kernel.h> | ||
| 5 | |||
| 6 | int mac_pton(const char *s, u8 *mac) | ||
| 7 | { | ||
| 8 | int i; | ||
| 9 | |||
| 10 | /* XX:XX:XX:XX:XX:XX */ | ||
| 11 | if (strlen(s) < 3 * ETH_ALEN - 1) | ||
| 12 | return 0; | ||
| 13 | |||
| 14 | /* Don't dirty result unless string is valid MAC. */ | ||
| 15 | for (i = 0; i < ETH_ALEN; i++) { | ||
| 16 | if (!isxdigit(s[i * 3]) || !isxdigit(s[i * 3 + 1])) | ||
| 17 | return 0; | ||
| 18 | if (i != ETH_ALEN - 1 && s[i * 3 + 2] != ':') | ||
| 19 | return 0; | ||
| 20 | } | ||
| 21 | for (i = 0; i < ETH_ALEN; i++) { | ||
| 22 | mac[i] = (hex_to_bin(s[i * 3]) << 4) | hex_to_bin(s[i * 3 + 1]); | ||
| 23 | } | ||
| 24 | return 1; | ||
| 25 | } | ||
| 26 | EXPORT_SYMBOL(mac_pton); | ||
