summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexander Aring <alex.aring@gmail.com>2014-10-27 17:13:35 +0100
committerMarcel Holtmann <marcel@holtmann.org>2014-10-27 18:07:43 +0100
commit702dcf994a0f0c467aae4b65885833a114126387 (patch)
tree344d289f803f5013081298063826d170a802528b
parentmac802154: rx: rename remove mac802154_subif_rx (diff)
downloadlinux-702dcf994a0f0c467aae4b65885833a114126387.tar.xz
linux-702dcf994a0f0c467aae4b65885833a114126387.zip
mac802154: rx: move skb->protocol setting
This patch moves the skb->protocol setting to the position when it's needed. It's only needed when frame parsing was successful. Signed-off-by: Alexander Aring <alex.aring@gmail.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
-rw-r--r--net/mac802154/rx.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/net/mac802154/rx.c b/net/mac802154/rx.c
index 246a60e8f76a..c4066b5006f1 100644
--- a/net/mac802154/rx.c
+++ b/net/mac802154/rx.c
@@ -31,6 +31,8 @@
static int mac802154_process_data(struct net_device *dev, struct sk_buff *skb)
{
+ skb->protocol = htons(ETH_P_IEEE802154);
+
return netif_receive_skb(skb);
}
@@ -224,6 +226,8 @@ mac802154_monitors_rx(struct ieee802154_local *local, struct sk_buff *skb)
u16 crc = crc_ccitt(0, skb->data, skb->len);
u8 *data;
+ skb->protocol = htons(ETH_P_IEEE802154);
+
rcu_read_lock();
list_for_each_entry_rcu(sdata, &local->interfaces, list) {
if (sdata->type != IEEE802154_DEV_MONITOR ||
@@ -248,7 +252,6 @@ void ieee802154_rx(struct ieee802154_hw *hw, struct sk_buff *skb)
WARN_ON_ONCE(softirq_count() == 0);
- skb->protocol = htons(ETH_P_IEEE802154);
skb_reset_mac_header(skb);
if (!(local->hw.flags & IEEE802154_HW_OMIT_CKSUM)) {