mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-12 00:00:00 +00:00
ieee802154: 6lowpan: change datagram var types
This patch changes datagram size variable from u16 type to unsigned int. The reason is that an IPv6 header has an MAX_UIN16 payload length, but the datagram size is payload + IPv6 header length. This avoids overflows at some places. Signed-off-by: Alexander Aring <alex.aring@gmail.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
This commit is contained in:
parent
5f2ebb3b59
commit
72d53b1162
@ -18,7 +18,7 @@ typedef unsigned __bitwise__ lowpan_rx_result;
|
|||||||
|
|
||||||
struct lowpan_create_arg {
|
struct lowpan_create_arg {
|
||||||
u16 tag;
|
u16 tag;
|
||||||
u16 d_size;
|
unsigned int d_size;
|
||||||
const struct ieee802154_addr *src;
|
const struct ieee802154_addr *src;
|
||||||
const struct ieee802154_addr *dst;
|
const struct ieee802154_addr *dst;
|
||||||
};
|
};
|
||||||
@ -29,7 +29,7 @@ struct lowpan_frag_queue {
|
|||||||
struct inet_frag_queue q;
|
struct inet_frag_queue q;
|
||||||
|
|
||||||
u16 tag;
|
u16 tag;
|
||||||
u16 d_size;
|
unsigned int d_size;
|
||||||
struct ieee802154_addr saddr;
|
struct ieee802154_addr saddr;
|
||||||
struct ieee802154_addr daddr;
|
struct ieee802154_addr daddr;
|
||||||
};
|
};
|
||||||
|
@ -37,7 +37,7 @@ static struct inet_frags lowpan_frags;
|
|||||||
static int lowpan_frag_reasm(struct lowpan_frag_queue *fq,
|
static int lowpan_frag_reasm(struct lowpan_frag_queue *fq,
|
||||||
struct sk_buff *prev, struct net_device *ldev);
|
struct sk_buff *prev, struct net_device *ldev);
|
||||||
|
|
||||||
static unsigned int lowpan_hash_frag(u16 tag, u16 d_size,
|
static unsigned int lowpan_hash_frag(u16 tag, unsigned int d_size,
|
||||||
const struct ieee802154_addr *saddr,
|
const struct ieee802154_addr *saddr,
|
||||||
const struct ieee802154_addr *daddr)
|
const struct ieee802154_addr *daddr)
|
||||||
{
|
{
|
||||||
|
@ -131,8 +131,8 @@ lowpan_xmit_fragment(struct sk_buff *skb, const struct ieee802154_hdr *wpan_hdr,
|
|||||||
|
|
||||||
static int
|
static int
|
||||||
lowpan_xmit_fragmented(struct sk_buff *skb, struct net_device *ldev,
|
lowpan_xmit_fragmented(struct sk_buff *skb, struct net_device *ldev,
|
||||||
const struct ieee802154_hdr *wpan_hdr, u16 dgram_size,
|
const struct ieee802154_hdr *wpan_hdr,
|
||||||
u16 dgram_offset)
|
unsigned int dgram_size, unsigned int dgram_offset)
|
||||||
{
|
{
|
||||||
__be16 frag_tag;
|
__be16 frag_tag;
|
||||||
u8 frag_hdr[5];
|
u8 frag_hdr[5];
|
||||||
@ -194,7 +194,7 @@ err:
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int lowpan_header(struct sk_buff *skb, struct net_device *ldev,
|
static int lowpan_header(struct sk_buff *skb, struct net_device *ldev,
|
||||||
u16 *dgram_size, u16 *dgram_offset)
|
unsigned int *dgram_size, unsigned int *dgram_offset)
|
||||||
{
|
{
|
||||||
struct wpan_dev *wpan_dev = lowpan_dev_info(ldev)->wdev->ieee802154_ptr;
|
struct wpan_dev *wpan_dev = lowpan_dev_info(ldev)->wdev->ieee802154_ptr;
|
||||||
struct ieee802154_addr sa, da;
|
struct ieee802154_addr sa, da;
|
||||||
@ -244,7 +244,7 @@ netdev_tx_t lowpan_xmit(struct sk_buff *skb, struct net_device *ldev)
|
|||||||
{
|
{
|
||||||
struct ieee802154_hdr wpan_hdr;
|
struct ieee802154_hdr wpan_hdr;
|
||||||
int max_single, ret;
|
int max_single, ret;
|
||||||
u16 dgram_size, dgram_offset;
|
unsigned int dgram_size, dgram_offset;
|
||||||
|
|
||||||
pr_debug("package xmit\n");
|
pr_debug("package xmit\n");
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user