1. 20 2月, 2019 4 次提交
  2. 19 2月, 2019 1 次提交
  3. 16 2月, 2019 2 次提交
  4. 09 2月, 2019 11 次提交
    • J
      RDMA/devices: Re-organize device.c locking · 921eab11
      Jason Gunthorpe 提交于
      The locking here started out with a single lock that covered everything
      and then has lately veered into crazy town.
      
      The fundamental problem is that several places need to iterate over a
      linked list, but also need to drop their locks to avoid deadlock during
      client callbacks.
      
      xarray's restartable iteration offers a simple solution to the
      problem. Once all the lists are xarrays we can drop locks in the places
      that need that and rely on xarray to provide consistency and locking for
      the data structure.
      
      The resulting simplification is that each of the three lists has a
      dedicated rwsem that must be held when working with the list it
      covers. One data structure is no longer covered by multiple locks.
      
      The sleeping semaphore is selected because the read side generally needs
      to be held over something sleeping, and using RCU reader locking in those
      cases is overkill.
      
      In the process this simplifies the entire registration/unregistration flow
      to be the expected list of setups and the reversed list of matching
      teardowns, and the registration lock 'refcount' can now be revised to be
      released after the ULPs are removed, providing a very sane semantic for
      this feature.
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      921eab11
    • J
      RDMA/devices: Use xarray to store the client_data · 0df91bb6
      Jason Gunthorpe 提交于
      Now that we have a small ID for each client we can use xarray instead of
      linearly searching linked lists for client data. This will give much
      faster and scalable client data lookup, and will lets us revise the
      locking scheme.
      
      Since xarray can store 'going_down' using a mark just entirely eliminate
      the struct ib_client_data and directly store the client_data value in the
      xarray. However this does require a special iterator as we must still
      iterate over any NULL client_data values.
      
      Also eliminate the client_data_lock in favour of internal xarray locking.
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      0df91bb6
    • J
      RDMA/devices: Use xarray to store the clients · e59178d8
      Jason Gunthorpe 提交于
      This gives each client a unique ID and will let us move client_data to use
      xarray, and revise the locking scheme.
      
      clients have to be add/removed in strict FIFO/LIFO order as they
      interdepend. To support this the client_ids are assigned to increase in
      FIFO order. The existing linked list is kept to support reverse iteration
      until xarray can get a reverse iteration API.
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      Reviewed-by: NParav Pandit <parav@mellanox.com>
      e59178d8
    • J
      RDMA/device: Use an ida instead of a free page in alloc_name · 3b88afd3
      Jason Gunthorpe 提交于
      ida is the proper data structure to hold list of clustered small integers
      and then allocate an unused integer. Get rid of the convoluted and limited
      open-coded bitmap.
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      3b88afd3
    • J
      RDMA/device: Get rid of reg_state · 652432f3
      Jason Gunthorpe 提交于
      This really has no purpose anymore, refcount can be used to tell if the
      device is still registered. Keeping it around just invites mis-use.
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      Reviewed-by: NParav Pandit <parav@mellanox.com>
      652432f3
    • J
      RDMA/device: Call ib_cache_release_one() only from ib_device_release() · d45f89d5
      Jason Gunthorpe 提交于
      Instead of complicated logic about when this memory is freed, always free
      it during device release(). All the cache pointers start out as NULL, so
      it is safe to call this before the cache is initialized.
      
      This makes for a simpler error unwind flow, and a simpler understanding of
      the lifetime of the memory allocations inside the struct ib_device.
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      d45f89d5
    • J
      RDMA/device: Ensure that security memory is always freed · b34b269a
      Jason Gunthorpe 提交于
      Since this only frees memory it should be done during the release
      callback. Otherwise there are possible error flows where it might not get
      called if registration aborts.
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      b34b269a
    • J
      RDMA/device: Check that the rename is nop under the lock · e3593b56
      Jason Gunthorpe 提交于
      Since another rename could be running in parallel it is safer to check
      that the name is not changing inside the lock, where we already know the
      device name will not change.
      
      Fixes: d21943dd ("RDMA/core: Implement IB device rename function")
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      Reviewed-by: NParav Pandit <parav@mellanox.com>
      e3593b56
    • L
      RDMA: Handle PD allocations by IB/core · 21a428a0
      Leon Romanovsky 提交于
      The PD allocations in IB/core allows us to simplify drivers and their
      error flows in their .alloc_pd() paths. The changes in .alloc_pd() go hand
      in had with relevant update in .dealloc_pd().
      
      We will use this opportunity and convert .dealloc_pd() to don't fail, as
      it was suggested a long time ago, failures are not happening as we have
      never seen a WARN_ON print.
      Signed-off-by: NLeon Romanovsky <leonro@mellanox.com>
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      21a428a0
    • L
      RDMA/core: Share driver structure size with core · 30471d4b
      Leon Romanovsky 提交于
      Add new macros to be used in drivers while registering ops structure and
      IB/core while calling allocation routines, so drivers won't need to
      perform kzalloc/kfree in their paths.
      
      The change in allocation stage allows us to initialize common fields prior
      to calling to drivers (e.g. restrack).
      Signed-off-by: NLeon Romanovsky <leonro@mellanox.com>
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      30471d4b
    • D
      IB/core: Don't register each MAD agent for LSM notifier · c66f6741
      Daniel Jurgens 提交于
      When creating many MAD agents in a short period of time, receive packet
      processing can be delayed long enough to cause timeouts while new agents
      are being added to the atomic notifier chain with IRQs disabled.  Notifier
      chain registration and unregstration is an O(n) operation. With large
      numbers of MAD agents being created and destroyed simultaneously the CPUs
      spend too much time with interrupts disabled.
      
      Instead of each MAD agent registering for it's own LSM notification,
      maintain a list of agents internally and register once, this registration
      already existed for handling the PKeys. This list is write mostly, so a
      normal spin lock is used vs a read/write lock. All MAD agents must be
      checked, so a single list is used instead of breaking them down per
      device.
      
      Notifier calls are done under rcu_read_lock, so there isn't a risk of
      similar packet timeouts while checking the MAD agents security settings
      when notified.
      Signed-off-by: NDaniel Jurgens <danielj@mellanox.com>
      Reviewed-by: NParav Pandit <parav@mellanox.com>
      Signed-off-by: NLeon Romanovsky <leonro@mellanox.com>
      Acked-by: NPaul Moore <paul@paul-moore.com>
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      c66f6741
  5. 31 1月, 2019 4 次提交
  6. 22 1月, 2019 1 次提交
  7. 19 1月, 2019 2 次提交
  8. 15 1月, 2019 2 次提交
  9. 03 1月, 2019 1 次提交
  10. 12 12月, 2018 2 次提交
  11. 08 12月, 2018 1 次提交
  12. 23 11月, 2018 1 次提交
    • P
      RDMA/core: Sync unregistration with netlink commands · 01b67117
      Parav Pandit 提交于
      When the rdma device is getting removed, get resource info can race with
      device removal, as below:
      
            CPU-0                                  CPU-1
          --------                               --------
          rdma_nl_rcv_msg()
             nldev_res_get_cq_dumpit()
                mutex_lock(device_lock);
                get device reference
                mutex_unlock(device_lock);        [..]
                                                  ib_unregister_device()
                                                  /* Valid reference to
                                                   * device->dev exists.
                                                   */
                                                   ib_dealloc_device()
      
                [..]
                provider->fill_res_entry();
      
      Even though device object is not freed, fill_res_entry() can get called on
      device which doesn't have a driver anymore. Kernel core device reference
      count is not sufficient, as this only keeps the structure valid, and
      doesn't guarantee the driver is still loaded.
      
      Similar race can occur with device renaming and device removal, where
      device_rename() tries to rename a unregistered device. While this is fine
      for devices of a class which are not net namespace aware, but it is
      incorrect for net namespace aware class coming in subsequent series.  If a
      class is net namespace aware, then the below [1] call trace is observed in
      above situation.
      
      Therefore, to avoid the race, keep a reference count and let device
      unregistration wait until all netlink users drop the reference.
      
      [1] Call trace:
      kernfs: ns required in 'infiniband' for 'mlx5_0'
      WARNING: CPU: 18 PID: 44270 at fs/kernfs/dir.c:842 kernfs_find_ns+0x104/0x120
      libahci i2c_core mlxfw libata dca [last unloaded: devlink]
      RIP: 0010:kernfs_find_ns+0x104/0x120
      Call Trace:
      kernfs_find_and_get_ns+0x2e/0x50
      sysfs_rename_link_ns+0x40/0xb0
      device_rename+0xb2/0xf0
      ib_device_rename+0xb3/0x100 [ib_core]
      nldev_set_doit+0x165/0x190 [ib_core]
      rdma_nl_rcv_msg+0x249/0x250 [ib_core]
      ? netlink_deliver_tap+0x8f/0x3e0
      rdma_nl_rcv+0xd6/0x120 [ib_core]
      netlink_unicast+0x17c/0x230
      netlink_sendmsg+0x2f0/0x3e0
      sock_sendmsg+0x30/0x40
      __sys_sendto+0xdc/0x160
      
      Fixes: da5c8507 ("RDMA/nldev: add driver-specific resource tracking")
      Signed-off-by: NParav Pandit <parav@mellanox.com>
      Signed-off-by: NLeon Romanovsky <leonro@mellanox.com>
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      01b67117
  13. 17 10月, 2018 3 次提交
  14. 27 9月, 2018 3 次提交
  15. 07 9月, 2018 2 次提交