diff options
Diffstat (limited to 'net/packet/af_packet.c')
-rw-r--r-- | net/packet/af_packet.c | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c index bf269907477..28d47e8f287 100644 --- a/net/packet/af_packet.c +++ b/net/packet/af_packet.c | |||
@@ -227,17 +227,14 @@ struct packet_skb_cb { | |||
227 | 227 | ||
228 | #ifdef CONFIG_PACKET_MMAP | 228 | #ifdef CONFIG_PACKET_MMAP |
229 | 229 | ||
230 | static inline char *packet_lookup_frame(struct packet_sock *po, unsigned int position) | 230 | static inline struct tpacket_hdr *packet_lookup_frame(struct packet_sock *po, unsigned int position) |
231 | { | 231 | { |
232 | unsigned int pg_vec_pos, frame_offset; | 232 | unsigned int pg_vec_pos, frame_offset; |
233 | char *frame; | ||
234 | 233 | ||
235 | pg_vec_pos = position / po->frames_per_block; | 234 | pg_vec_pos = position / po->frames_per_block; |
236 | frame_offset = position % po->frames_per_block; | 235 | frame_offset = position % po->frames_per_block; |
237 | 236 | ||
238 | frame = po->pg_vec[pg_vec_pos] + (frame_offset * po->frame_size); | 237 | return (struct tpacket_hdr *)(po->pg_vec[pg_vec_pos] + (frame_offset * po->frame_size)); |
239 | |||
240 | return frame; | ||
241 | } | 238 | } |
242 | #endif | 239 | #endif |
243 | 240 | ||
@@ -639,7 +636,7 @@ static int tpacket_rcv(struct sk_buff *skb, struct net_device *dev, struct packe | |||
639 | } | 636 | } |
640 | 637 | ||
641 | spin_lock(&sk->sk_receive_queue.lock); | 638 | spin_lock(&sk->sk_receive_queue.lock); |
642 | h = (struct tpacket_hdr *)packet_lookup_frame(po, po->head); | 639 | h = packet_lookup_frame(po, po->head); |
643 | 640 | ||
644 | if (h->tp_status) | 641 | if (h->tp_status) |
645 | goto ring_is_full; | 642 | goto ring_is_full; |
@@ -1473,7 +1470,7 @@ static int packet_notifier(struct notifier_block *this, unsigned long msg, void | |||
1473 | { | 1470 | { |
1474 | struct sock *sk; | 1471 | struct sock *sk; |
1475 | struct hlist_node *node; | 1472 | struct hlist_node *node; |
1476 | struct net_device *dev = (struct net_device*)data; | 1473 | struct net_device *dev = data; |
1477 | 1474 | ||
1478 | read_lock(&packet_sklist_lock); | 1475 | read_lock(&packet_sklist_lock); |
1479 | sk_for_each(sk, node, &packet_sklist) { | 1476 | sk_for_each(sk, node, &packet_sklist) { |
@@ -1588,7 +1585,7 @@ static unsigned int packet_poll(struct file * file, struct socket *sock, | |||
1588 | unsigned last = po->head ? po->head-1 : po->frame_max; | 1585 | unsigned last = po->head ? po->head-1 : po->frame_max; |
1589 | struct tpacket_hdr *h; | 1586 | struct tpacket_hdr *h; |
1590 | 1587 | ||
1591 | h = (struct tpacket_hdr *)packet_lookup_frame(po, last); | 1588 | h = packet_lookup_frame(po, last); |
1592 | 1589 | ||
1593 | if (h->tp_status) | 1590 | if (h->tp_status) |
1594 | mask |= POLLIN | POLLRDNORM; | 1591 | mask |= POLLIN | POLLRDNORM; |