diff mbox

[1/2] igb: Support sending custom Ethernet FCS.

Message ID 1330997441-13324-1-git-send-email-greearb@candelatech.com
State Awaiting Upstream, archived
Delegated to: David Miller
Headers show

Commit Message

Ben Greear March 6, 2012, 1:30 a.m. UTC
From: Ben Greear <greearb@candelatech.com>

Including bad FCS, used generate frames with bad FCS
to test other system's handling of RX of bad packets.

Signed-off-by: Ben Greear <greearb@candelatech.com>
---
:100644 100644 fda8247... e4058ac... M	drivers/net/ethernet/intel/igb/igb_main.c
 drivers/net/ethernet/intel/igb/igb_main.c |    4 ++++
 1 files changed, 4 insertions(+), 0 deletions(-)

Comments

Kirsher, Jeffrey T March 6, 2012, 1:34 a.m. UTC | #1
On Mon, 2012-03-05 at 17:30 -0800, greearb@candelatech.com wrote:
> From: Ben Greear <greearb@candelatech.com>
> 
> Including bad FCS, used generate frames with bad FCS
> to test other system's handling of RX of bad packets.
> 
> Signed-off-by: Ben Greear <greearb@candelatech.com>
> ---
> :100644 100644 fda8247... e4058ac...
> M  drivers/net/ethernet/intel/igb/igb_main.c
>  drivers/net/ethernet/intel/igb/igb_main.c |    4 ++++
>  1 files changed, 4 insertions(+), 0 deletions(-) 

I have added these as well to my queue, thanks Ben!
diff mbox

Patch

diff --git a/drivers/net/ethernet/intel/igb/igb_main.c b/drivers/net/ethernet/intel/igb/igb_main.c
index fda8247..e4058ac 100644
--- a/drivers/net/ethernet/intel/igb/igb_main.c
+++ b/drivers/net/ethernet/intel/igb/igb_main.c
@@ -1964,6 +1964,8 @@  static int __devinit igb_probe(struct pci_dev *pdev,
 				 NETIF_F_IPV6_CSUM |
 				 NETIF_F_SG;
 
+	netdev->priv_flags |= IFF_SUPP_NOFCS;
+
 	if (pci_using_dac) {
 		netdev->features |= NETIF_F_HIGHDMA;
 		netdev->vlan_features |= NETIF_F_HIGHDMA;
@@ -4292,6 +4294,8 @@  static void igb_tx_map(struct igb_ring *tx_ring,
 
 	/* write last descriptor with RS and EOP bits */
 	cmd_type |= cpu_to_le32(size) | cpu_to_le32(IGB_TXD_DCMD);
+	if (unlikely(skb->no_fcs))
+		cmd_type &= ~(cpu_to_le32(E1000_ADVTXD_DCMD_IFCS));
 	tx_desc->read.cmd_type_len = cmd_type;
 
 	/* set the timestamp */