1. 24 8月, 2019 12 次提交
  2. 23 8月, 2019 18 次提交
  3. 22 8月, 2019 10 次提交
    • E
      net/mlx5e: Add mlx5e HV VHCA stats agent · cef35af3
      Eran Ben Elisha 提交于
      HV VHCA stats agent is responsible on running a preiodic rx/tx
      packets/bytes stats update. Currently the supported format is version
      MLX5_HV_VHCA_STATS_VERSION. Block ID 1 is dedicated for statistics data
      transfer from the VF to the PF.
      
      The reporter fetch the statistics data from all opened channels, fill it
      in a buffer and send it to mlx5_hv_vhca_write_agent.
      
      As the stats layer should include some metadata per block (sequence and
      offset), the HV VHCA layer shall modify the buffer before actually send it
      over block 1.
      Signed-off-by: NEran Ben Elisha <eranbe@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      Signed-off-by: NHaiyang Zhang <haiyangz@microsoft.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      cef35af3
    • E
      net/mlx5: Add HV VHCA control agent · 29ddad43
      Eran Ben Elisha 提交于
      Control agent is responsible over of the control block (ID 0). It should
      update the PF via this block about every capability change. In addition,
      upon block 0 invalidate, it should activate all other supported agents
      with data requests from the PF.
      
      Upon agent create/destroy, the invalidate callback of the control agent
      is being called in order to update the PF driver about this change.
      
      The control agent is an integral part of HV VHCA and will be created
      and destroy as part of the HV VHCA init/cleanup flow.
      Signed-off-by: NEran Ben Elisha <eranbe@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      Signed-off-by: NHaiyang Zhang <haiyangz@microsoft.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      29ddad43
    • E
      net/mlx5: Add HV VHCA infrastructure · 87175120
      Eran Ben Elisha 提交于
      HV VHCA is a layer which provides PF to VF communication channel based on
      HyperV PCI config channel. It implements Mellanox's Inter VHCA control
      communication protocol. The protocol contains control block in order to
      pass messages between the PF and VF drivers, and data blocks in order to
      pass actual data.
      
      The infrastructure is agent based. Each agent will be responsible of
      contiguous buffer blocks in the VHCA config space. This infrastructure will
      bind agents to their blocks, and those agents can only access read/write
      the buffer blocks assigned to them. Each agent will provide three
      callbacks (control, invalidate, cleanup). Control will be invoked when
      block-0 is invalidated with a command that concerns this agent. Invalidate
      callback will be invoked if one of the blocks assigned to this agent was
      invalidated. Cleanup will be invoked before the agent is being freed in
      order to clean all of its open resources or deferred works.
      
      Block-0 serves as the control block. All execution commands from the PF
      will be written by the PF over this block. VF will ack on those by
      writing on block-0 as well. Its format is described by struct
      mlx5_hv_vhca_control_block layout.
      Signed-off-by: NEran Ben Elisha <eranbe@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      Signed-off-by: NHaiyang Zhang <haiyangz@microsoft.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      87175120
    • E
      net/mlx5: Add wrappers for HyperV PCIe operations · 913d14e8
      Eran Ben Elisha 提交于
      Add wrapper functions for HyperV PCIe read / write /
      block_invalidate_register operations.  This will be used as an
      infrastructure in the downstream patch for software communication.
      
      This will be enabled by default if CONFIG_PCI_HYPERV_INTERFACE is set.
      Signed-off-by: NEran Ben Elisha <eranbe@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      Signed-off-by: NHaiyang Zhang <haiyangz@microsoft.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      913d14e8
    • V
      net/mlx5e: Add trace point for neigh update · 5970882a
      Vlad Buslov 提交于
      Allow tracing neigh state during neigh update task that is executed on
      workqueue and is scheduled by neigh state change event.
      
      Usage example:
       ># cd /sys/kernel/debug/tracing
       ># echo mlx5:mlx5e_rep_neigh_update >> set_event
       ># cat trace
          ...
          kworker/u48:7-2221  [009] ...1  1475.387435: mlx5e_rep_neigh_update:
      netdev: ens1f0 MAC: 24:8a:07:9a:17:9a IPv4: 1.1.1.10 IPv6: ::ffff:1.1.1.10 neigh_connected=1
      
      Added corresponding documentation in
          Documentation/networking/device-driver/mellanox/mlx5.rst
      Signed-off-by: NVlad Buslov <vladbu@mellanox.com>
      Reviewed-by: NDmytro Linkin <dmitrolin@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      5970882a
    • V
      net/mlx5e: Add trace point for neigh used value update · c786fe59
      Vlad Buslov 提交于
      Allow tracing result of neigh used value update task that is executed
      periodically on workqueue.
      
      Usage example:
       ># cd /sys/kernel/debug/tracing
       ># echo mlx5:mlx5e_tc_update_neigh_used_value >> set_event
       ># cat trace
          ...
          kworker/u48:4-8806  [009] ...1 55117.882428: mlx5e_tc_update_neigh_used_value:
      netdev: ens1f0 IPv4: 1.1.1.10 IPv6: ::ffff:1.1.1.10 neigh_used=1
      
      Added corresponding documentation in
          Documentation/networking/device-driver/mellanox/mlx5.rst
      Signed-off-by: NVlad Buslov <vladbu@mellanox.com>
      Reviewed-by: NDmytro Linkin <dmitrolin@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      c786fe59
    • D
      net/mlx5e: Add tc flower tracepoints · 7a978759
      Dmytro Linkin 提交于
      Implemented following tracepoints:
      1. Configure flower (mlx5e_configure_flower)
      2. Delete flower (mlx5e_delete_flower)
      3. Stats flower (mlx5e_stats_flower)
      
      Usage example:
       ># cd /sys/kernel/debug/tracing
       ># echo mlx5:mlx5e_configure_flower >> set_event
       ># cat trace
          ...
          tc-6535  [019] ...1  2672.404466: mlx5e_configure_flower: cookie=0000000067874a55 actions= REDIRECT
      
      Added corresponding documentation in
          Documentation/networking/device-driver/mellanox/mlx5.rst
      Signed-off-by: NDmytro Linkin <dmitrolin@mellanox.com>
      Reviewed-by: NVlad Buslov <vladbu@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      7a978759
    • V
      net/mlx5e: Only access fully initialized flows in neigh update · 95435ad7
      Vlad Buslov 提交于
      To remove dependency on rtnl lock and prevent neigh update code from
      accessing uninitialized flows when executing concurrently with tc, extend
      mlx5e_tc_flow with 'init_done' completion. Modify helper
      mlx5e_take_all_encap_flows() to wait for flow completion after obtaining
      reference to it. Modify mlx5e_tc_encap_flows_del() and
      mlx5e_tc_encap_flows_add() to skip flows that don't have OFFLOADED flag
      set, which can happen if concurrent flow initialization failed.
      
      This commit finishes neigh update refactoring for concurrent execution
      started in previous change in this series.
      Signed-off-by: NVlad Buslov <vladbu@mellanox.com>
      Reviewed-by: NRoi Dayan <roid@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      95435ad7
    • V
      net/mlx5e: Refactor neigh update for concurrent execution · 2a1f1768
      Vlad Buslov 提交于
      In order to remove dependency on rtnl lock and allow neigh update workqueue
      task to execute concurrently with tc, refactor mlx5e_rep_neigh_update() for
      concurrent execution:
      
      - Lock encap table when accessing encap entry to prevent concurrent
        changes. To do this properly, the initial encap state check is moved from
        mlx5e_rep_neigh_update() into mlx5e_rep_update_flows() to be performed
        under encap_tbl_lock protection.
      
      - Wait for encap to be fully initialized before accessing it by means of
        'res_ready' completion.
      
      - Add mlx5e_take_all_encap_flows() helper which is used to construct a
        temporary list of flows and efi indexes that is used to access current
        encap data in flow which can be attached to multiple encaps
        simultaneously. Release the flows from temporary list after
        encap_tbl_lock critical section. This is necessary because
        mlx5e_flow_put() can't be called while holding encap_tbl_lock.
      
      - Modify mlx5e_tc_encap_flows_add() and mlx5e_tc_encap_flows_del() to work
        with user-provided list of flows built by mlx5e_take_all_encap_flows(),
        instead of traversing encap flow list directly.
      
      This is first step in complex neigh update refactoring, which is finished
      by following commit in this series.
      Signed-off-by: NVlad Buslov <vladbu@mellanox.com>
      Reviewed-by: NRoi Dayan <roid@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      2a1f1768
    • V
      net/mlx5e: Refactor neigh used value update for concurrent execution · 6a06c2f7
      Vlad Buslov 提交于
      In order to remove dependency on rtnl lock and allow neigh used value
      update workqueue task to execute concurrently with tc, refactor
      mlx5e_tc_update_neigh_used_value() for concurrent execution:
      
      - Lock encap table when accessing encap entry to prevent concurrent
        changes.
      
      - Save offloaded encap flows to temporary list and release them after encap
        entry is updated. Add mlx5e_put_encap_flow_list() helper which is
        intended to be shared with neigh update code in following patch in this
        series. This is necessary because mlx5e_flow_put() can't be called while
        holding encap_tbl_lock.
      Signed-off-by: NVlad Buslov <vladbu@mellanox.com>
      Reviewed-by: NRoi Dayan <roid@mellanox.com>
      Signed-off-by: NSaeed Mahameed <saeedm@mellanox.com>
      6a06c2f7