David S. Miller 9b3e446cd0 mlx5-updates-2022-02-14
mlx5 TX routines improvements
 
 1) From Aya and Tariq, first 3 patches, Use the Max size of the TX descriptor
 as advertised by the device and not the fixed value of 16 that the driver
 always assumed, this is not a bug fix as all existing devices have Max value
 larger than 16, but the series is necessary for future proofing the driver.
 
 2) TX Synchronization improvements from Maxim, last 12 patches
 
 Maxim Mikityanskiy Says:
 =======================
 mlx5e: Synchronize ndo_select_queue with configuration changes
 
 The kernel can call ndo_select_queue at any time, and there is no direct
 way to block it. The implementation of ndo_select_queue in mlx5e expects
 the parameters to be consistent and may crash (invalid pointer, division
 by zero) if they aren't.
 
 There were attempts to partially fix some of the most frequent crashes,
 see commit 846d6da1fcdb ("net/mlx5e: Fix division by 0 in
 mlx5e_select_queue") and commit 84c8a87402cf ("net/mlx5e: Fix division
 by 0 in mlx5e_select_queue for representors"). However, they don't
 address the issue completely.
 
 This series introduces the proper synchronization mechanism between
 mlx5e configuration and TX data path:
 
 1. txq2sq updates are synchronized properly with ndo_start_xmit
    (mlx5e_xmit). The TX queue is stopped when it configuration is being
    updated, and memory barriers ensure the changes are visible before
    restarting.
 
 2. The set of parameters needed for mlx5e_select_queue is reduced, and
    synchronization using RCU is implemented. This way, changes are
    atomic, and the state in mlx5e_select_queue is always consistent.
 
 3. A few optimizations are applied to the new implementation of
    mlx5e_select_queue.
 
 =======================
 -----BEGIN PGP SIGNATURE-----
 
 iQEzBAABCAAdFiEEGhZs6bAKwk/OTgTpSD+KveBX+j4FAmILSJwACgkQSD+KveBX
 +j6BjwgAj4tGNrIuR8wByLq7gFG+h8t/A80TkqxgNHFhYuF3u6bS6UnmymCAsM3F
 G8jFott6Pu/4d7SQvksrtVQJvTTj+TinZFeLGNxYXLwm/Syk6Avbs2c02eDL1CbQ
 fUE4HavgwpS+hp8xvdWOUH+i5b+e7I+iF6JC/K0LULHUhXaJ7BXiQi3qCm7DKwLm
 gVdWzDHNBj73Xmxak71CH0b79qdIBMs0JlZjdizE++8vg/AZ8CY2G51UUTmjJk5h
 YASXBigbmGAP5o30IWxjYaj51UQTmWmR5A1XhNIC4iVdWjFOPcz6k8M5EfB0ADq+
 eXkQKGDiyMDddKAaor611K0n9H4Ogw==
 =SDns
 -----END PGP SIGNATURE-----

Merge tag 'mlx5-updates-2022-02-14' of git://git.kernel.org/pub/scm/linux/kernel/git/saeed/linux

Saeed Mahameed says:

====================
mlx5-updates-2022-02-14

mlx5 TX routines improvements

1) From Aya and Tariq, first 3 patches, Use the Max size of the TX descriptor
as advertised by the device and not the fixed value of 16 that the driver
always assumed, this is not a bug fix as all existing devices have Max value
larger than 16, but the series is necessary for future proofing the driver.

2) TX Synchronization improvements from Maxim, last 12 patches

Maxim Mikityanskiy Says:
=======================
mlx5e: Synchronize ndo_select_queue with configuration changes

The kernel can call ndo_select_queue at any time, and there is no direct
way to block it. The implementation of ndo_select_queue in mlx5e expects
the parameters to be consistent and may crash (invalid pointer, division
by zero) if they aren't.

There were attempts to partially fix some of the most frequent crashes,
see commit 846d6da1fcdb ("net/mlx5e: Fix division by 0 in
mlx5e_select_queue") and commit 84c8a87402cf ("net/mlx5e: Fix division
by 0 in mlx5e_select_queue for representors"). However, they don't
address the issue completely.

This series introduces the proper synchronization mechanism between
mlx5e configuration and TX data path:

1. txq2sq updates are synchronized properly with ndo_start_xmit
   (mlx5e_xmit). The TX queue is stopped when it configuration is being
   updated, and memory barriers ensure the changes are visible before
   restarting.

2. The set of parameters needed for mlx5e_select_queue is reduced, and
   synchronization using RCU is implemented. This way, changes are
   atomic, and the state in mlx5e_select_queue is always consistent.

3. A few optimizations are applied to the new implementation of
   mlx5e_select_queue.

=======================

====================

Signed-off-by: David S. Miller <davem@davemloft.net>
2022-02-15 10:35:09 +00:00
2022-02-09 09:56:57 -08:00
2022-02-01 16:52:54 +01:00
2022-01-28 19:00:26 +02:00
2022-02-06 12:20:50 -08:00

Linux kernel
============

There are several guides for kernel developers and users. These guides can
be rendered in a number of formats, like HTML and PDF. Please read
Documentation/admin-guide/README.rst first.

In order to build the documentation, use ``make htmldocs`` or
``make pdfdocs``.  The formatted documentation can also be read online at:

    https://www.kernel.org/doc/html/latest/

There are various text files in the Documentation/ subdirectory,
several of them using the Restructured Text markup notation.

Please read the Documentation/process/changes.rst file, as it contains the
requirements for building and running the kernel, and information about
the problems which may result by upgrading your kernel.
Description
No description provided
Readme 5.7 GiB
Languages
C 97.6%
Assembly 1%
Shell 0.5%
Python 0.3%
Makefile 0.3%