mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-26 20:55:22 +07:00
5f509239ec
This reverts commit 9abc378c66e3d6f437eed77c1c534cbc183523f7 ("ieee802154: 6lowpan: change datagram var types"). The reason is that I forgot the IPv6 fragmentation here. Our MTU of lowpan interface is 1280 and skb->len should not above of that. If we reach a payload above 1280 in IPv6 header then we have a IPv6 fragmentation above 802.15.4 6LoWPAN fragmentation. The type "u16" was fine, instead I added now a WARN_ON_ONCE if skb->len is above MTU which should never happen otherwise IPv6 on minimum MTU size is broken. Signed-off-by: Alexander Aring <alex.aring@gmail.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
78 lines
1.9 KiB
C
78 lines
1.9 KiB
C
#ifndef __IEEE802154_6LOWPAN_I_H__
|
|
#define __IEEE802154_6LOWPAN_I_H__
|
|
|
|
#include <linux/list.h>
|
|
|
|
#include <net/ieee802154_netdev.h>
|
|
#include <net/inet_frag.h>
|
|
#include <net/6lowpan.h>
|
|
|
|
typedef unsigned __bitwise__ lowpan_rx_result;
|
|
#define RX_CONTINUE ((__force lowpan_rx_result) 0u)
|
|
#define RX_DROP_UNUSABLE ((__force lowpan_rx_result) 1u)
|
|
#define RX_DROP ((__force lowpan_rx_result) 2u)
|
|
#define RX_QUEUED ((__force lowpan_rx_result) 3u)
|
|
|
|
#define LOWPAN_DISPATCH_FRAG1 0xc0
|
|
#define LOWPAN_DISPATCH_FRAGN 0xe0
|
|
|
|
struct lowpan_create_arg {
|
|
u16 tag;
|
|
u16 d_size;
|
|
const struct ieee802154_addr *src;
|
|
const struct ieee802154_addr *dst;
|
|
};
|
|
|
|
/* Equivalent of ipv4 struct ip
|
|
*/
|
|
struct lowpan_frag_queue {
|
|
struct inet_frag_queue q;
|
|
|
|
u16 tag;
|
|
u16 d_size;
|
|
struct ieee802154_addr saddr;
|
|
struct ieee802154_addr daddr;
|
|
};
|
|
|
|
static inline u32 ieee802154_addr_hash(const struct ieee802154_addr *a)
|
|
{
|
|
switch (a->mode) {
|
|
case IEEE802154_ADDR_LONG:
|
|
return (((__force u64)a->extended_addr) >> 32) ^
|
|
(((__force u64)a->extended_addr) & 0xffffffff);
|
|
case IEEE802154_ADDR_SHORT:
|
|
return (__force u32)(a->short_addr);
|
|
default:
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
/* private device info */
|
|
struct lowpan_dev_info {
|
|
struct net_device *wdev; /* wpan device ptr */
|
|
u16 fragment_tag;
|
|
};
|
|
|
|
static inline struct
|
|
lowpan_dev_info *lowpan_dev_info(const struct net_device *dev)
|
|
{
|
|
return (struct lowpan_dev_info *)lowpan_priv(dev)->priv;
|
|
}
|
|
|
|
int lowpan_frag_rcv(struct sk_buff *skb, const u8 frag_type);
|
|
void lowpan_net_frag_exit(void);
|
|
int lowpan_net_frag_init(void);
|
|
|
|
void lowpan_rx_init(void);
|
|
void lowpan_rx_exit(void);
|
|
|
|
int lowpan_header_create(struct sk_buff *skb, struct net_device *dev,
|
|
unsigned short type, const void *_daddr,
|
|
const void *_saddr, unsigned int len);
|
|
netdev_tx_t lowpan_xmit(struct sk_buff *skb, struct net_device *dev);
|
|
|
|
int lowpan_iphc_decompress(struct sk_buff *skb);
|
|
lowpan_rx_result lowpan_rx_h_ipv6(struct sk_buff *skb);
|
|
|
|
#endif /* __IEEE802154_6LOWPAN_I_H__ */
|