diff options
author | Guo-Fu Tseng <cooldavid@cooldavid.org> | 2009-07-06 00:41:22 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-07-06 16:05:11 -0400 |
commit | ce7d70af2c8b9c74e8afb2c0d69e304d141ce4aa (patch) | |
tree | 8e463f11f68e7b7087942488e4e455d447b52672 /drivers/net | |
parent | d1dfa1d1de855e8db58ec4e403af5939d273f8fe (diff) |
jme: Tuning rxsum function
1. Use more efficient way to determine flag status.
2. Hardware dose not mark fragment bit against IPv6 packets,
print TCP/UDP checksum warning message for IPv4 packets
only.
Signed-off-by: Guo-Fu Tseng <cooldavid@cooldavid.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/jme.c | 26 |
1 files changed, 13 insertions, 13 deletions
diff --git a/drivers/net/jme.c b/drivers/net/jme.c index 29cd5f43eea5..e7068c7cd627 100644 --- a/drivers/net/jme.c +++ b/drivers/net/jme.c | |||
@@ -880,27 +880,27 @@ jme_rxsum_ok(struct jme_adapter *jme, u16 flags) | |||
880 | if (!(flags & (RXWBFLAG_TCPON | RXWBFLAG_UDPON | RXWBFLAG_IPV4))) | 880 | if (!(flags & (RXWBFLAG_TCPON | RXWBFLAG_UDPON | RXWBFLAG_IPV4))) |
881 | return false; | 881 | return false; |
882 | 882 | ||
883 | if (unlikely(!(flags & RXWBFLAG_MF) && | 883 | if (unlikely((flags & (RXWBFLAG_MF | RXWBFLAG_TCPON | RXWBFLAG_TCPCS)) |
884 | (flags & RXWBFLAG_TCPON) && !(flags & RXWBFLAG_TCPCS))) { | 884 | == RXWBFLAG_TCPON)) { |
885 | msg_rx_err(jme, "TCP Checksum error.\n"); | 885 | if (flags & RXWBFLAG_IPV4) |
886 | goto out_sumerr; | 886 | msg_rx_err(jme, "TCP Checksum error\n"); |
887 | return false; | ||
887 | } | 888 | } |
888 | 889 | ||
889 | if (unlikely(!(flags & RXWBFLAG_MF) && | 890 | if (unlikely((flags & (RXWBFLAG_MF | RXWBFLAG_UDPON | RXWBFLAG_UDPCS)) |
890 | (flags & RXWBFLAG_UDPON) && !(flags & RXWBFLAG_UDPCS))) { | 891 | == RXWBFLAG_UDPON)) { |
891 | msg_rx_err(jme, "UDP Checksum error.\n"); | 892 | if (flags & RXWBFLAG_IPV4) |
892 | goto out_sumerr; | 893 | msg_rx_err(jme, "UDP Checksum error.\n"); |
894 | return false; | ||
893 | } | 895 | } |
894 | 896 | ||
895 | if (unlikely((flags & RXWBFLAG_IPV4) && !(flags & RXWBFLAG_IPCS))) { | 897 | if (unlikely((flags & (RXWBFLAG_IPV4 | RXWBFLAG_IPCS)) |
898 | == RXWBFLAG_IPV4)) { | ||
896 | msg_rx_err(jme, "IPv4 Checksum error.\n"); | 899 | msg_rx_err(jme, "IPv4 Checksum error.\n"); |
897 | goto out_sumerr; | 900 | return false; |
898 | } | 901 | } |
899 | 902 | ||
900 | return true; | 903 | return true; |
901 | |||
902 | out_sumerr: | ||
903 | return false; | ||
904 | } | 904 | } |
905 | 905 | ||
906 | static void | 906 | static void |