1. 14 8月, 2021 4 次提交
  2. 13 8月, 2021 2 次提交
  3. 12 8月, 2021 23 次提交
  4. 11 8月, 2021 11 次提交
    • P
      net/mlx5: Support enable_vnet devlink dev param · 70862a5d
      Parav Pandit 提交于
      Enable user to disable VDPA net auxiliary device so that when it is not
      required, user can disable it.
      
      For example,
      
      $ devlink dev param set pci/0000:06:00.0 \
                    name enable_vnet value false cmode driverinit
      $ devlink dev reload pci/0000:06:00.0
      
      At this point devlink instance do not create auxiliary device
      mlx5_core.vnet.2 for the VDPA net functionality.
      Signed-off-by: NParav Pandit <parav@nvidia.com>
      Reviewed-by: NLeon Romanovsky <leonro@nvidia.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      70862a5d
    • P
      net/mlx5: Support enable_rdma devlink dev param · 87158ced
      Parav Pandit 提交于
      Enable user to disable RDMA auxiliary device so that when it is not
      required, user can disable it.
      
      For example,
      
      $ devlink dev param set pci/0000:06:00.0 \
                    name enable_rdma value false cmode driverinit
      $ devlink dev reload pci/0000:06:00.0
      
      At this point devlink instance do not create auxiliary device
      mlx5_core.rdma.2 for the RDMA functionality.
      Signed-off-by: NParav Pandit <parav@nvidia.com>
      Reviewed-by: NLeon Romanovsky <leonro@nvidia.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      87158ced
    • P
      net/mlx5: Support enable_eth devlink dev param · a17beb28
      Parav Pandit 提交于
      Enable user to disable Ethernet auxiliary device so that when it is not
      required, user can disable it.
      
      For example,
      
      $ devlink dev param set pci/0000:06:00.0 \
                    name enable_eth value false cmode driverinit
      $ devlink dev reload pci/0000:06:00.0
      
      At this point devlink instance do not create mlx5_core.eth.2 auxiliary
      device for the Ethernet functionality.
      Signed-off-by: NParav Pandit <parav@nvidia.com>
      Reviewed-by: NLeon Romanovsky <leonro@nvidia.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      a17beb28
    • P
      net/mlx5: Fix unpublish devlink parameters · 6f357238
      Parav Pandit 提交于
      Cleanup routine missed to unpublish the parameters. Add it.
      
      Fixes: e890acd5 ("net/mlx5: Add devlink flow_steering_mode parameter")
      Signed-off-by: NParav Pandit <parav@nvidia.com>
      Reviewed-by: NJiri Pirko <jiri@nvidia.com>
      Reviewed-by: NLeon Romanovsky <leonro@nvidia.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      6f357238
    • A
      net: ipa: kill ipa_clock_get_additional() · 0d08026a
      Alex Elder 提交于
      Now that ipa_clock_get_additional() is a trivial wrapper around
      pm_runtime_get_if_active(), just open-code it in its only caller
      and delete the function.
      Signed-off-by: NAlex Elder <elder@linaro.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      0d08026a
    • A
      net: ipa: kill IPA clock reference count · a71aeff3
      Alex Elder 提交于
      The runtime power management core code maintains a usage count.  This
      count mirrors the IPA clock reference count, and there's no need to
      maintain both.  So get rid of the IPA clock reference count and just
      rely on the runtime PM usage count to determine when the hardware
      should be suspended or resumed.
      
      Use pm_runtime_get_if_active() in ipa_clock_get_additional().  We
      care whether power is active, regardless of whether it's in use, so
      pass true for its ign_usage_count argument.
      
      The IPA clock mutex is just used to make enabling/disabling the
      clock and updating the reference count occur atomically.  Without
      the reference count, there's no need for the mutex, so get rid of
      that too.
      Signed-off-by: NAlex Elder <elder@linaro.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      a71aeff3
    • A
      net: ipa: get rid of extra clock reference · a3d3e759
      Alex Elder 提交于
      Suspending the IPA hardware is now managed by the runtime PM core
      code.  The ->runtime_idle callback returns a non-zero value, so it
      will never suspend except when forced.  As a result, there's no need
      to take an extra "do not suspend" clock reference.
      Signed-off-by: NAlex Elder <elder@linaro.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      a3d3e759
    • A
      net: ipa: use runtime PM core · 63de79f0
      Alex Elder 提交于
      Use the runtime power management core to cause hardware suspend and
      resume to occur.  Enable it in ipa_clock_init() (without autosuspend),
      and disable it in ipa_clock_exit().
      
      Use ipa_runtime_suspend() as the ->runtime_suspend power operation,
      and arrange for it to be called by having ipa_clock_get() call
      pm_runtime_get_sync() when the first clock reference is taken.
      Similarly, use ipa_runtime_resume() as the ->runtime_resume power
      operation, and pm_runtime_put() when the last IPA clock reference
      is dropped.
      
      Introduce ipa_runtime_idle() as the ->runtime_idle power operation,
      and have it return a non-zero value; this way suspend will never
      occur except when forced.
      
      Use pm_runtime_force_suspend() and pm_runtime_force_resume() as the
      system suspend and resume callbacks, and remove ipa_suspend() and
      ipa_resume().
      
      Store a pointer to the device structure passed to ipa_clock_init(),
      so it can be used by ipa_clock_exit() to disable runtime power
      management.
      
      For now we preserve IPA clock reference counting.
      Signed-off-by: NAlex Elder <elder@linaro.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      63de79f0
    • A
      net: ipa: resume in ipa_clock_get() · 2abb0c7f
      Alex Elder 提交于
      Introduce ipa_runtime_suspend() and ipa_runtime_resume(), which
      encapsulate the activities necessary for suspending and resuming
      the IPA hardware.  Call these functions from ipa_clock_get() and
      ipa_clock_put() when the first reference is taken or last one is
      dropped.
      
      When the very first clock reference is taken (for ipa_config()),
      setup isn't complete yet, so (as before) only the core clock gets
      enabled.
      
      When the last clock reference is dropped (after ipa_deconfig()),
      ipa_teardown() will have made the setup_complete flag false, so
      there too, the core clock will be stopped without affecting GSI
      or the endpoints.
      
      Otherwise these new functions will perform the desired suspend and
      resume actions once setup is complete.
      Signed-off-by: NAlex Elder <elder@linaro.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      2abb0c7f
    • A
      net: ipa: disable clock in suspend · 1016c6b8
      Alex Elder 提交于
      Disable the IPA clock rather than dropping a reference to it in the
      system suspend callback.  This forces the suspend to occur without
      affecting existing references.
      
      Similarly, enable the clock rather than taking a reference in
      ipa_resume(), forcing a resume without changing the reference count.
      Signed-off-by: NAlex Elder <elder@linaro.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      1016c6b8
    • A
      net: ipa: have ipa_clock_get() return a value · 7ebd168c
      Alex Elder 提交于
      We currently assume no errors occur when enabling or disabling the
      IPA core clock and interconnects.  And although this commit exposes
      errors that could occur, we generally assume this won't happen in
      practice.
      
      This commit changes ipa_clock_get() and ipa_clock_put() so each
      returns a value.  The values returned are meant to mimic what the
      runtime power management functions return, so we can set up error
      handling here before we make the switch.  Have ipa_clock_get()
      increment the reference count even if it returns an error, to match
      the behavior of pm_runtime_get().
      
      More details follow.
      
      When taking a reference in ipa_clock_get(), return 0 for the first
      reference, 1 for subsequent references, or a negative error code if
      an error occurs.  Note that if ipa_clock_get() returns an error, we
      must not touch hardware; in some cases such errors now cause entire
      blocks of code to be skipped.
      
      When dropping a reference in ipa_clock_put(), we return 0 or an
      error code.  The error would come from ipa_clock_disable(), which
      now returns what ipa_interconnect_disable() returns (either 0 or a
      negative error code).  For now, callers ignore the return value;
      if an error occurs, a message will have already been logged, and
      little more can actually be done to improve the situation.
      Signed-off-by: NAlex Elder <elder@linaro.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      7ebd168c