1. 10 6月, 2019 2 次提交
  2. 04 6月, 2019 1 次提交
  3. 29 5月, 2019 2 次提交
  4. 27 5月, 2019 2 次提交
  5. 04 5月, 2019 2 次提交
    • J
      net: hns3: add support for FEC encoding control · 7e6ec914
      Jian Shen 提交于
      This patch adds support for FEC encoding control, user can change
      FEC mode by command ethtool --set-fec, and get FEC mode by command
      ethtool --show-fec. The fec capability is changed follow the port
      speed. If autoneg on, the user configure fec mode will be overwritten
      by autoneg result.
      Signed-off-by: NJian Shen <shenjian15@huawei.com>
      Signed-off-by: NPeng Li <lipeng321@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      7e6ec914
    • J
      net: hns3: add support for multiple media type · 88d10bd6
      Jian Shen 提交于
      Previously, we can only identify copper and fiber type, the
      supported link modes of port information are always showing
      SR type. This patch adds support for multiple media types,
      include SR, LR CR, KR. Driver needs to query the media type
      from firmware periodicly, and updates the port information.
      
      The new port information looks like this:
      Settings for eth0:
              Supported ports: [ FIBRE ]
              Supported link modes:   25000baseCR/Full
                                      25000baseSR/Full
                                      1000baseX/Full
                                      10000baseCR/Full
                                      10000baseSR/Full
                                      10000baseLR/Full
              Supported pause frame use: Symmetric
              Supports auto-negotiation: No
              Supported FEC modes: None BaseR
              Advertised link modes:  Not reported
              Advertised pause frame use: No
              Advertised auto-negotiation: No
              Advertised FEC modes: Not reported
              Speed: 10000Mb/s
              Duplex: Full
              Port: FIBRE
              PHYAD: 0
              Transceiver: internal
              Auto-negotiation: off
              Current message level: 0x00000036 (54)
                                     probe link ifdown ifup
              Link detected: yes
      
      In order to be compatible with old firmware which only support
      sfp speed, we remained using the same query command, and kept
      the former logic.
      Signed-off-by: NJian Shen <shenjian15@huawei.com>
      Signed-off-by: NPeng Li <lipeng321@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      88d10bd6
  6. 20 4月, 2019 2 次提交
  7. 16 4月, 2019 1 次提交
  8. 15 4月, 2019 3 次提交
  9. 25 2月, 2019 1 次提交
  10. 22 2月, 2019 3 次提交
  11. 31 1月, 2019 1 次提交
  12. 24 1月, 2019 2 次提交
  13. 19 1月, 2019 1 次提交
  14. 19 12月, 2018 1 次提交
  15. 16 12月, 2018 1 次提交
  16. 08 12月, 2018 1 次提交
    • S
      net: hns3: add handling of hw errors reported through MSIX · f6162d44
      Salil Mehta 提交于
      This patch adds handling for HNS3 hardware errors(non-standard)
      which are reported through MSIX interrupts and not through
      PCIe AER channel.
      
      These MSIX reported hardware errors are handled using common
      misc. interrupt handler. Hardware error related registers
      cannot be cleared in context to the interrupt received as
      they require *heavy* access to hardware using IMP(Integrated
      Mangement Processor) commands. Hence, we defer the clearing
      of such error events till later time.
      
      Since, we have defered exact identification of errors we
      will have to defer the level of receovery/reset which
      might be required. Hence, a new reset type UNKNOWN reset
      has been introduced which effectively defers the assertion
      of the reset till we get hold of kind of errors at later
      time.
      Signed-off-by: NSalil Mehta <salil.mehta@huawei.com>
      Signed-off-by: NShiju Jose <shiju.jose@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      f6162d44
  17. 04 12月, 2018 1 次提交
  18. 28 11月, 2018 1 次提交
  19. 24 11月, 2018 1 次提交
    • L
      net: hns3: Add "FD flow table" info query function · 3c666b58
      liuzhongzhu 提交于
      All the Flow Director rules are stored in tcam blocks.
      For each bit of tcam entry, the match value
      depends on two input value(x, y).
      
      debugfs command:
      echo dump fd tcam > cmd
      
      Sample output:
      root@(none)# echo dump fd tcam > cmd
      hns3 0000:7d:00.0: read result tcam key x(31):
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 08000000
      hns3 0000:7d:00.0: 00000600
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: read result tcam key y(31):
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: f7ff0000
      hns3 0000:7d:00.0: 0000f900
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 00000000
      hns3 0000:7d:00.0: 0000fff8
      root@(none)#
      Signed-off-by: Nliuzhongzhu <liuzhongzhu@huawei.com>
      Signed-off-by: NSalil Mehta <salil.mehta@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      3c666b58
  20. 18 11月, 2018 3 次提交
  21. 10 11月, 2018 4 次提交
    • H
      net: hns3: add PCIe FLR support for PF · 6b9a97ee
      Huazhong Tan 提交于
      This patch implements the .reset_prepare and .reset_done
      ops from pci framework to support the PF FLR.
      Signed-off-by: NHuazhong Tan <tanhuazhong@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      6b9a97ee
    • H
      net: hns3: implement the IMP reset processing for PF · 6dd22bbc
      Huazhong Tan 提交于
      The current code only print the prompt message after receiving
      the IMP reset interrupt and does not perform the corresponding driver
      reset operation. This patch implements the missing IMP reset handling
      in the driver.
      1. The driver sets the HCLGE_STATE_CMD_DISABLE to stop sending command
         after receiving the IMP reset interrupt.
      2. The driver needs to notify the hardware to reload the IMP firmware.
      3. The IMP firmware reloading makes the reset time of hardware longer,
         so it is necessary to extend the driver's waiting time to wait for
         the hardware reset to complete.
      4. In hclge_check_event_cause, IMP reset event should have higher
         priority than other events.
      
      Also, after clearing HCLGE_STATE_CMD_DISABLE in the hclge_cmd_init(),
      it needs to check whether there is a pending reset, if so, just set
      the HCLGE_STATE_CMD_DISABLE back and return.
      Signed-off-by: NHuazhong Tan <tanhuazhong@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      6dd22bbc
    • H
      net: hns3: add reset handling for VF when doing PF reset · aa5c4f17
      Huazhong Tan 提交于
      When PF performs a function reset, the hardware will reset both PF
      and all the VF belong to this PF. Hence, both PF's driver and VF's
      driver need to perform corresponding reset operations.
      
      Before PF driver asserting function reset to hardware, it firstly
      set up VF's hardware reset status, and inform the VF driver with
      HNAE3_VF_PF_FUNC_RESET, then VF driver sets this reset type to
      reset_pending and shechule reset task to stop IO and waits for the
      hardware reset status to clear. When PF driver has reinitialized the
      hardware and is ready to process mailbox from VF, PF driver clears
      VF's hardware reset status for VF to continue its reset process.
      
      Also, this patch uses readl_poll_timeout to simplify the hardware reset
      status waitting.
      Signed-off-by: NHuazhong Tan <tanhuazhong@huawei.com>
      Signed-off-by: NYunsheng Lin <linyunsheng@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      aa5c4f17
    • H
      net: hns3: adjust VF's reset process · dea846e8
      Huazhong Tan 提交于
      Currently when VF need to reset itself, it will send a cmd to PF,
      after receiving the VF reset requset, PF sends a cmd to inform
      VF to enter the reset process and send a cmd to firmware to do the
      actual reset for the VF, it is possible that firmware has resetted
      the VF, but VF has not entered the reset process, which may cause
      IO not stopped problem when firmware is resetting VF.
      
      This patch fixes it by adjusting the VF reset process, when VF
      need to reset itself, it will enter the reset process first, and
      it will tell the PF to send cmd to firmware to reset itself.
      
      Add member reset_pending to struct hclgevf_dev, which indicates that
      there is reset event need to be processed by the VF's reset task, and
      the VF's reset task chooses the highest-level one and clears other
      low-level one when it processes reset_pending.
      
      hclge_inform_reset_assert_to_vf function is unused now, but it will
      be used to support the PF reset with VF working, so declare it in
      the header file.
      Signed-off-by: NHuazhong Tan <tanhuazhong@huawei.com>
      Signed-off-by: NYunsheng Lin <linyunsheng@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      dea846e8
  22. 08 11月, 2018 4 次提交
    • H
      net: hns3: add error handler for hclge_reset() · 65e41e7e
      Huazhong Tan 提交于
      When hclge_reset() is called, it may fail for several reasons.
      For example, an higher-level reset event occurs, memory allocation
      failure, hardware reset timeout, etc. Therefore, it is necessary
      to add corresponding error handling for these situations.
      1. A high-level reset is required due to a high-level reset failure.
      2. For memory allocation failure, a high-level reset is initiated by
      the timer to recover. The reason for using the timer is to prevent this
      new high-level reset to interrupt the reset process of other pf/vf;
      3. For the case of hardware reset timeout, reschedule the reset task
      to wait for the hardware to complete the reset.
      For memory allocation failure and reset timeouts, in order to prevent
      an infinite number of scheduled reset tasks, the number of error
      recovery needs to be limited.
      
      This patch also add some reset related debug log printing.
      Signed-off-by: NHuazhong Tan <tanhuazhong@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      65e41e7e
    • H
      net: hns3: move some reset information from hnae3_handle into hclge_dev/hclgevf_dev · 0742ed7c
      Huazhong Tan 提交于
      Saving reset related information in the hclge_dev/hclgevf_dev
      structure is more suitable than the hnae3_handle, since hardware
      related information is kept in these two structure.
      Signed-off-by: NHuazhong Tan <tanhuazhong@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      0742ed7c
    • H
      net: hns3: provide some interface & information for the client · 4d60291b
      Huazhong Tan 提交于
      The client needs to know if the hardware is resetting when
      loading or unloading itself, because client may abort the loading
      process or wait for the reset process to finish when unloading
      if hardware is resetting.
      
      So this patch provides these interfaces to do it.
      1. get_hw_reset_stat, the reset status of hardware.
      2. ae_dev_resetting, whether reset task is scheduling.
      3. ae_dev_reset_cnt, how many reset has been done.
      
      Also, the RoCE client needs some field in the hnae3_roce_private_info
      to save its state, and process_hw_error interface in the
      hnae3_client_ops to process hardware errors.
      Signed-off-by: NHuazhong Tan <tanhuazhong@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      4d60291b
    • H
      net: hns3: add set_default_reset_request in the hnae3_ae_ops · 720bd583
      Huazhong Tan 提交于
      Currently, when reset_event is called because of tx timeout, it will
      upgrade the reset level (For PF, HNAE3_FUNC_RESET -> HNAE3_CORE_RESET
      -> HNAE3_GLOBAL_RESET) if the time between the new reset and last reset
      is within 20 secs, or restore the reset level to HNAE3_FUNC_RESET if
      the time between the new reset and last reset is over 20 secs.
      
      There is requirement that the caller needs to decide the reset level
      when triggering a reset, for example, RAS recovery. So this patch
      adds the set_default_reset_request to meet this requirement.
      Signed-off-by: NHuazhong Tan <tanhuazhong@huawei.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      720bd583