1. 02 12月, 2017 6 次提交
  2. 16 11月, 2017 1 次提交
    • G
      net: ethernet: ti: cpsw: fix min eth packet size · 9421c901
      Grygorii Strashko 提交于
      Now CPSW driver configures min eth packet size to 60 octets (ETH_ZLEN)
      which works in most of cases, but when port VLAN is configured on some
      switch port, it also can be configured to force all egress packets to be
      VLAN untagged. And in this case, CPSW driver will pad small packets to 60
      octets, but final packet size on port egress can became less than 60 octets
      due to VLAN tag removal and packet will be dropped.
      
      Hence, fix it by accounting VLAN header in CPSW min eth packet size. While
      here, use proper defines for CPSW_MAX_PACKET_SIZE also, instead of open
      coding.
      Signed-off-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      9421c901
  3. 14 8月, 2017 1 次提交
  4. 25 7月, 2017 1 次提交
  5. 21 7月, 2017 1 次提交
  6. 30 6月, 2017 2 次提交
  7. 14 6月, 2017 1 次提交
  8. 11 6月, 2017 1 次提交
  9. 22 5月, 2017 1 次提交
  10. 09 5月, 2017 1 次提交
    • G
      net: ethernet: ti: cpsw: adjust cpsw fifos depth for fullduplex flow control · 48f5bccc
      Grygorii Strashko 提交于
      When users set flow control using ethtool the bits are set properly in the
      CPGMAC_SL MACCONTROL register, but the FIFO depth in the respective Port n
      Maximum FIFO Blocks (Pn_MAX_BLKS) registers remains set to the minimum size
      reset value. When receive flow control is enabled on a port, the port's
      associated FIFO block allocation must be adjusted. The port RX allocation
      must increase to accommodate the flow control runout. The TRM recommends
      numbers of 5 or 6.
      
      Hence, apply required Port FIFO configuration to
      Pn_MAX_BLKS.Pn_TX_MAX_BLKS=0xF and Pn_MAX_BLKS.Pn_RX_MAX_BLKS=0x5 during
      interface initialization.
      
      Cc: Schuyler Patton <spatton@ti.com>
      Signed-off-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      48f5bccc
  11. 05 4月, 2017 1 次提交
    • S
      net: ethernet: ti: cpsw: fix race condition during open() · 30c57f07
      Sekhar Nori 提交于
      TI's cpsw driver handles both OF and non-OF case for phy
      connect. Unfortunately of_phy_connect() returns NULL on
      error while phy_connect() returns ERR_PTR().
      
      To handle this, cpsw_slave_open() overrides the return value
      from phy_connect() to make it NULL or error.
      
      This leaves a small window, where cpsw_adjust_link() may be
      invoked for a slave while slave->phy pointer is temporarily
      set to -ENODEV (or some other error) before it is finally set
      to NULL.
      
      _cpsw_adjust_link() only handles the NULL case, and an oops
      results when ERR_PTR() is seen by it.
      
      Note that cpsw_adjust_link() checks PHY status for each
      slave whenever it is invoked. It can so happen that even
      though phy_connect() for a given slave returns error,
      _cpsw_adjust_link() is still called for that slave because
      the link status of another slave changed.
      
      Fix this by using a temporary pointer to store return value
      of {of_}phy_connect() and do a one-time write to slave->phy.
      Reviewed-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Reported-by: NYan Liu <yan-liu@ti.com>
      Signed-off-by: NSekhar Nori <nsekhar@ti.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      30c57f07
  12. 03 4月, 2017 1 次提交
  13. 18 2月, 2017 1 次提交
  14. 15 2月, 2017 2 次提交
  15. 12 2月, 2017 1 次提交
  16. 08 2月, 2017 1 次提交
  17. 02 2月, 2017 1 次提交
  18. 31 1月, 2017 1 次提交
  19. 21 1月, 2017 5 次提交
  20. 10 1月, 2017 1 次提交
  21. 08 1月, 2017 2 次提交
    • G
      net: ethernet: ti: cpsw: add support for ringparam configuration · be034fc1
      Grygorii Strashko 提交于
      The CPDMA uses one pool of descriptors for both RX and TX which by default
      split between all channels proportionally depending on total number of
      CPDMA channels and number of TX and RX channels. As result, more
      descriptors will be consumed by TX path if there are more TX channels and
      there is no way now to dedicate more descriptors for RX path.
      
      So, add the ability to re-split CPDMA pool of descriptors between RX and TX
      path via ethtool '-G' command wich will allow to configure and fix number
      of descriptors used by RX and TX path, which, then, will be split between
      RX/TX channels proportionally depending on RX/TX channels number and
      weight. ethtool '-G' command will accept only number of RX entries and rest
      of descriptors will be arranged for TX automatically.
      
      Command:
        ethtool -G <devname> rx <number of descriptors>
      
      defaults and limitations:
      - minimum number of rx descriptors is 10% of total number of descriptors in
        CPDMA pool
      - maximum number of rx descriptors is 90% of total number of descriptors in
        CPDMA pool
      - by default, descriptors will be split equally between RX/TX path
      - any values passed in "tx" parameter will be ignored
      
      Usage:
      
       # ethtool -g eth0
      	Pre-set maximums:
      	RX:             7372
      	RX Mini:        0
      	RX Jumbo:       0
      	TX:             0
      	Current hardware settings:
      	RX:             4096
      	RX Mini:        0
      	RX Jumbo:       0
      	TX:             4096
      
       # ethtool -G eth0 rx 7372
       # ethtool -g eth0
      	Ring parameters for eth0:
      	Pre-set maximums:
      	RX:             7372
      	RX Mini:        0
      	RX Jumbo:       0
      	TX:             0
      	Current hardware settings:
      	RX:             7372
      	RX Mini:        0
      	RX Jumbo:       0
      	TX:             820
      Signed-off-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      be034fc1
    • G
      net: ethernet: ti: cpsw: add support for descs pool size configuration · 90225bf0
      Grygorii Strashko 提交于
      The CPSW CPDMA can process buffer descriptors placed as in internal
      CPPI RAM as in DDR. This patch adds support in CPSW and CPDMA for
      descs_pool_size mudule parameter, which defines total number of CPDMA CPPI
      descriptors to be used for both ingress/egress packets processing:
       - memory size, required for CPDMA descriptor pool, is calculated basing
      on number of descriptors specified by user in descs_pool_size and
      CPDMA descriptor size and allocated from coherent memory (CMA area);
       - CPDMA descriptor pool will be allocated in DDR if pool memory size >
      internal CPPI RAM or use internal CPPI RAM otherwise;
       - if descs_pool_size not specified in DT - the default value 256 will
      be used which will allow to place CPDMA descriptors pool into the
      internal CPPI RAM (current default behaviour);
       - CPDMA will ignore descs_pool_size if descs_pool_size = 0 for
      backward comaptiobility with davinci_emac.
      
      descs_pool_size is boot time setting and can't be changed once
      CPSW/CPDMA is initialized.
      Signed-off-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      90225bf0
  22. 11 12月, 2016 5 次提交
  23. 08 12月, 2016 2 次提交
    • G
      net: ethernet: ti: cpts: move dt props parsing to cpts driver · 4a88fb95
      Grygorii Strashko 提交于
      Move DT properties parsing into CPTS driver to simplify CPSW
      code and CPTS driver porting on other SoC in the future
      (like Keystone 2) - with this change it will not be required
      to add the same DT parsing code in Keystone 2 NETCP driver.
      Signed-off-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      4a88fb95
    • G
      net: ethernet: ti: cpts: rework initialization/deinitialization · 8a2c9a5a
      Grygorii Strashko 提交于
      The current implementation CPTS initialization and deinitialization
      (represented by cpts_register/unregister()) does too many static
      initialization from .ndo_open(), which is reasonable to do once at probe
      time instead, and also require caller to allocate memory for struct cpts,
      which is internal for CPTS driver in general.
      
      This patch splits CPTS initialization and deinitialization on two parts:
      
      - static initializtion cpts_create()/cpts_release() which expected to be
      executed when parent driver is probed/removed;
      
      - dynamic part cpts_register/unregister() which expected to be executed
      when network device is opened/closed.
      
      As result, current code of CPTS parent driver - CPSW - will be simplified
      (and it also will allow simplify adding support for Keystone 2 devices in
      the future), plus more initialization errors will be catched earlier. In
      addition, this change allows to clean up cpts.h for the case when CPTS is
      disabled.
      Signed-off-by: NGrygorii Strashko <grygorii.strashko@ti.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      8a2c9a5a