diff options
| author | Marcelo Tosatti <mtosatti@redhat.com> | 2012-08-26 13:58:41 -0300 | 
|---|---|---|
| committer | Marcelo Tosatti <mtosatti@redhat.com> | 2012-08-26 13:58:41 -0300 | 
| commit | c78aa4c4b94b5b148be576a9f1570e31fe282b46 (patch) | |
| tree | 6d5801eb3e60bcec6a91c7b13a334c6d2ea11b05 /net/packet/af_packet.c | |
| parent | 90993cdd1800dc6ef9587431a0c625b978584e81 (diff) | |
| parent | 9acb172543aecb783e2e1e53e3f447d4c0f5c150 (diff) | |
Merge remote-tracking branch 'upstream/master' into queue
Merging critical fixes from upstream required for development.
* upstream/master: (809 commits)
  libata: Add a space to " 2GB ATA Flash Disk" DMA blacklist entry
  Revert "powerpc: Update g5_defconfig"
  powerpc/perf: Use pmc_overflow() to detect rolled back events
  powerpc: Fix VMX in interrupt check in POWER7 copy loops
  powerpc: POWER7 copy_to_user/copy_from_user patch applied twice
  powerpc: Fix personality handling in ppc64_personality()
  powerpc/dma-iommu: Fix IOMMU window check
  powerpc: Remove unnecessary ifdefs
  powerpc/kgdb: Restore current_thread_info properly
  powerpc/kgdb: Bail out of KGDB when we've been triggered
  powerpc/kgdb: Do not set kgdb_single_step on ppc
  powerpc/mpic_msgr: Add missing includes
  powerpc: Fix null pointer deref in perf hardware breakpoints
  powerpc: Fixup whitespace in xmon
  powerpc: Fix xmon dl command for new printk implementation
  xfs: check for possible overflow in xfs_ioc_trim
  xfs: unlock the AGI buffer when looping in xfs_dialloc
  xfs: fix uninitialised variable in xfs_rtbuf_get()
  powerpc/fsl: fix "Failed to mount /dev: No such device" errors
  powerpc/fsl: update defconfigs
  ...
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Diffstat (limited to 'net/packet/af_packet.c')
| -rw-r--r-- | net/packet/af_packet.c | 12 | 
1 files changed, 10 insertions, 2 deletions
| diff --git a/net/packet/af_packet.c b/net/packet/af_packet.c index ceaca7c134a0..aee7196aac36 100644 --- a/net/packet/af_packet.c +++ b/net/packet/af_packet.c @@ -1079,7 +1079,7 @@ static void *packet_current_rx_frame(struct packet_sock *po,  	default:  		WARN(1, "TPACKET version not supported\n");  		BUG(); -		return 0; +		return NULL;  	}  } @@ -1273,6 +1273,14 @@ static void __fanout_unlink(struct sock *sk, struct packet_sock *po)  	spin_unlock(&f->lock);  } +bool match_fanout_group(struct packet_type *ptype, struct sock * sk) +{ +	if (ptype->af_packet_priv == (void*)((struct packet_sock *)sk)->fanout) +		return true; + +	return false; +} +  static int fanout_add(struct sock *sk, u16 id, u16 type_flags)  {  	struct packet_sock *po = pkt_sk(sk); @@ -1325,6 +1333,7 @@ static int fanout_add(struct sock *sk, u16 id, u16 type_flags)  		match->prot_hook.dev = po->prot_hook.dev;  		match->prot_hook.func = packet_rcv_fanout;  		match->prot_hook.af_packet_priv = match; +		match->prot_hook.id_match = match_fanout_group;  		dev_add_pack(&match->prot_hook);  		list_add(&match->list, &fanout_list);  	} @@ -1936,7 +1945,6 @@ static void tpacket_destruct_skb(struct sk_buff *skb)  	if (likely(po->tx_ring.pg_vec)) {  		ph = skb_shinfo(skb)->destructor_arg; -		BUG_ON(__packet_get_status(po, ph) != TP_STATUS_SENDING);  		BUG_ON(atomic_read(&po->tx_ring.pending) == 0);  		atomic_dec(&po->tx_ring.pending);  		__packet_set_status(po, ph, TP_STATUS_AVAILABLE); | 
