Make the memset possibly more efficient with the appropriate CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS #ifdef
Signed-off-by: Joe Perches <j...@perches.com> --- include/linux/etherdevice.h | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/include/linux/etherdevice.h b/include/linux/etherdevice.h index 606563e..22ad94a 100644 --- a/include/linux/etherdevice.h +++ b/include/linux/etherdevice.h @@ -192,7 +192,12 @@ static inline void eth_random_addr(u8 *addr) */ static inline void eth_broadcast_addr(u8 *addr) { +#if defined(CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS) + *(u32 *)addr = 0xffffffff; + *(u16 *)(addr + 4) = 0xffff; +#else memset(addr, 0xff, ETH_ALEN); +#endif } /** @@ -203,7 +208,12 @@ static inline void eth_broadcast_addr(u8 *addr) */ static inline void eth_zero_addr(u8 *addr) { - memset(addr, 0x00, ETH_ALEN); +#if defined(CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS) + *(u32 *)addr = 0; + *(u16 *)(addr + 4) = 0; +#else + memset(addr, 0, ETH_ALEN); +#endif } /** -- 2.1.2 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/