summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexander Aring <alex.aring@gmail.com>2014-11-05 22:51:24 +0300
committerMarcel Holtmann <marcel@holtmann.org>2014-11-05 23:53:05 +0300
commit705cbbbe9ccca260658f971a4369c22f5704db75 (patch)
tree2dd83c1c2334a2c80502085a6ebeaa3d6e434213
parent239a84a9a0bcbc7214eb93fb3ba76962de846239 (diff)
downloadlinux-705cbbbe9ccca260658f971a4369c22f5704db75.tar.xz
mac802154: cleanup ieee802154_netdev_to_extended_addr
This patch cleanups the ieee802154_be64_to_le64 to have a similar function like ieee802154_le64_to_be64 only with switched source and destionation types. Signed-off-by: Alexander Aring <alex.aring@gmail.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
-rw-r--r--include/net/mac802154.h11
-rw-r--r--net/mac802154/iface.c2
2 files changed, 8 insertions, 5 deletions
diff --git a/include/net/mac802154.h b/include/net/mac802154.h
index cc188cb4f94d..632f6566adb5 100644
--- a/include/net/mac802154.h
+++ b/include/net/mac802154.h
@@ -224,12 +224,15 @@ struct ieee802154_ops {
};
/**
- * ieee802154_netdev_to_extended_addr - convert big endian 64 byte void pointer to __le64
- * @dev_addr: big endian address pointer like netdevice dev_addr attribute
+ * ieee802154_be64_to_le64 - copies and convert be64 to le64
+ * @le64_dst: le64 destination pointer
+ * @be64_src: be64 source pointer
*/
-static inline __le64 ieee802154_netdev_to_extended_addr(const void *dev_addr)
+static inline void ieee802154_be64_to_le64(void *le64_dst, const void *be64_src)
{
- return (__force __le64)swab64p(dev_addr);
+ __le64 tmp = (__force __le64)swab64p(be64_src);
+
+ memcpy(le64_dst, &tmp, IEEE802154_EXTENDED_ADDR_LEN);
}
/**
diff --git a/net/mac802154/iface.c b/net/mac802154/iface.c
index 764ce496fdc3..a1aa09b03d12 100644
--- a/net/mac802154/iface.c
+++ b/net/mac802154/iface.c
@@ -117,7 +117,7 @@ static int mac802154_wpan_mac_addr(struct net_device *dev, void *p)
if (netif_running(dev))
return -EBUSY;
- extended_addr = ieee802154_netdev_to_extended_addr(addr->sa_data);
+ ieee802154_be64_to_le64(&extended_addr, addr->sa_data);
if (!ieee802154_is_valid_extended_addr(extended_addr))
return -EINVAL;