diff options
author | Giuseppe CAVALLARO <peppe.cavallaro@st.com> | 2010-09-16 23:23:40 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-09-17 19:12:57 -0400 |
commit | ebbb293f8b3021ae2009fcb7cb3b8a52fb5fd06a (patch) | |
tree | 9ee381c887f2bc585c103a34b349d85fd95a2567 /drivers/net/stmmac/dwmac100_core.c | |
parent | dfb8fb96ae2b5126cd0c08c0ccd7c42e1f46568a (diff) |
stmmac: consolidate and tidy-up the COE support
The first version of the driver had hard-coded the logic
for handling the checksum offloading.
This was designed according to the chips included in
the STM platforms where:
o MAC10/100 supports no COE at all.
o GMAC fully supports RX/TX COE.
This is not good for other chip configurations where,
for example, the mac10/100 supports the tx csum in HW
or when the GMAC has no IPC.
Thanks to Johannes Stezenbach; he provided me a first
draft of this patch that only reviewed the IPC for the
GMAC devices.
This patch also helps on SPEAr platforms where the
MAC10/100 can perform the TX csum in HW.
Thanks to Deepak SIKRI for his support on this.
In the end, GMAC devices for STM platforms have
a bugged Jumbo frame support that needs to have
the Tx COE disabled for oversized frames (due to
limited buffer sizes). This information is also
passed through the driver's platform structure.
Signed-off-by: Giuseppe Cavallaro <peppe.cavallaro@st.com>
Signed-off-by: Johannes Stezenbach <js@sig21.net>
Signed-off-by: Deepak SIKRI <deepak.sikri@st.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/stmmac/dwmac100_core.c')
-rw-r--r-- | drivers/net/stmmac/dwmac100_core.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/net/stmmac/dwmac100_core.c b/drivers/net/stmmac/dwmac100_core.c index db06c04ce48..58a914b2700 100644 --- a/drivers/net/stmmac/dwmac100_core.c +++ b/drivers/net/stmmac/dwmac100_core.c | |||
@@ -42,6 +42,11 @@ static void dwmac100_core_init(void __iomem *ioaddr) | |||
42 | #endif | 42 | #endif |
43 | } | 43 | } |
44 | 44 | ||
45 | static int dwmac100_rx_coe_supported(void __iomem *ioaddr) | ||
46 | { | ||
47 | return 0; | ||
48 | } | ||
49 | |||
45 | static void dwmac100_dump_mac_regs(void __iomem *ioaddr) | 50 | static void dwmac100_dump_mac_regs(void __iomem *ioaddr) |
46 | { | 51 | { |
47 | pr_info("\t----------------------------------------------\n" | 52 | pr_info("\t----------------------------------------------\n" |
@@ -165,6 +170,7 @@ static void dwmac100_pmt(void __iomem *ioaddr, unsigned long mode) | |||
165 | 170 | ||
166 | struct stmmac_ops dwmac100_ops = { | 171 | struct stmmac_ops dwmac100_ops = { |
167 | .core_init = dwmac100_core_init, | 172 | .core_init = dwmac100_core_init, |
173 | .rx_coe = dwmac100_rx_coe_supported, | ||
168 | .dump_regs = dwmac100_dump_mac_regs, | 174 | .dump_regs = dwmac100_dump_mac_regs, |
169 | .host_irq_status = dwmac100_irq_status, | 175 | .host_irq_status = dwmac100_irq_status, |
170 | .set_filter = dwmac100_set_filter, | 176 | .set_filter = dwmac100_set_filter, |