Re: [PATCH net-next v2 0/2] stmmac: fix kernel crashes for jumbo frames

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




Hi Vince

On Tue, 2014-01-14 at 08:40 -0600, Vince Bridgers wrote:
> These patches address two kernel crashes seen when using jumbo frames on 
> the Synopsys stmmac driver, and adds device tree configurability for the 
> maximum mtu. The Synopsys emac fifo sizes can be configured when a logic
> design is synthesized, but does not provide a way for a driver to query the
> exact fifo size. 
> 
> The crashes seen were due to two issues. 
> 
> 1) The dma buffer size was being set after the dma buffers were allocated.
> This caused a crash when changing the mtu since it was possible the buffers
> would subsequently be freed using an incorrect dma buffer size. This could
> also cause kernel panics due to memory corruption since a large mtu size could
> have been configured, but the dma buffers were not sized accordingly. 
> 
> 2) Jumbo frames were being enabled by default, but the dma buffers were not
> sized accordingly. This caused memory corruption in the context of certain
> types of network traffic, leading to kernel panics. 
> 
> I've tested these changes using automated, reproducible testware. I can
> demonstrate the panics described before the fixes and show that the fixes
> address the problems described. 
> 
> Testing and improvements continue through the use of the mentioned automated
> and reproducible testware. 
> 
> Vince Bridgers
> 
> Vince Bridgers (2):
>   dts: Add a binding for Synopsys emac max-frame-size
>   stmmac: Fix kernel crashes for jumbo frames
> 
>  Documentation/devicetree/bindings/net/stmmac.txt   |    5 +++++
>  drivers/net/ethernet/stmicro/stmmac/common.h       |    4 +++-
>  drivers/net/ethernet/stmicro/stmmac/dwmac1000.h    |    7 ++-----
>  .../net/ethernet/stmicro/stmmac/dwmac1000_core.c   |    7 ++++++-
>  .../net/ethernet/stmicro/stmmac/dwmac100_core.c    |    2 +-
>  drivers/net/ethernet/stmicro/stmmac/stmmac_main.c  |   11 +++++++----
>  .../net/ethernet/stmicro/stmmac/stmmac_platform.c  |    5 +++++
>  include/linux/stmmac.h                             |    1 +
>  8 files changed, 30 insertions(+), 12 deletions(-)


What has changed since v1? A version log would be nice.

Thanks,
Dinh


--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[Index of Archives]     [Device Tree Compilter]     [Device Tree Spec]     [Linux Driver Backports]     [Video for Linux]     [Linux USB Devel]     [Linux PCI Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [XFree86]     [Yosemite Backpacking]
  Powered by Linux