[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20220517163450.240299-1-miquel.raynal@bootlin.com>
Date: Tue, 17 May 2022 18:34:39 +0200
From: Miquel Raynal <miquel.raynal@...tlin.com>
To: Alexander Aring <alex.aring@...il.com>,
Stefan Schmidt <stefan@...enfreihafen.org>,
linux-wpan@...r.kernel.org
Cc: David Girault <david.girault@...vo.com>,
Romuald Despres <romuald.despres@...vo.com>,
Frederic Blain <frederic.blain@...vo.com>,
Nicolas Schodet <nico@...fr.eu.org>,
Thomas Petazzoni <thomas.petazzoni@...tlin.com>,
"David S. Miller" <davem@...emloft.net>,
Jakub Kicinski <kuba@...nel.org>,
Paolo Abeni <pabeni@...hat.com>, netdev@...r.kernel.org,
Miquel Raynal <miquel.raynal@...tlin.com>
Subject: [PATCH wpan-next v3 00/11] ieee802154: Synchronous Tx support
Hello,
This series brings support for that famous synchronous Tx API for MLME
commands.
MLME commands will be used during scan operations. In this situation,
we need to be sure that all transfers finished and that no transfer
will be queued for a short moment.
Cheers,
Miquèl
Changes in v3:
* Tested with lockdep enabled, a more aggressive preemption level and
the sleeping while atomic warnings enabled.
* Changed the hold/release queue mutex into a spinlock.
* Split the mlme_tx function into three, one to hold the queue, then
another part that does takes the rtnl and has the real content, and a
last helper to release the queue.
* Fixed the warning condition in the slow path.
* Used an unsigned long and test/set_bit helpers to follow the queue
state instead of an atomic_t.
Changes in v2:
* Updated the main tx function error path.
* Added a missing atomic_dec_at_test() call on the hold counter.
* Always called (upon a certain condition) the queue wakeup helper from
the release queue helper (and similarly in the hold helper) and
squashed two existing patches in it to simplify the series.
* Introduced a mutex to serialize accesses to the increment/decrement of
the hold counter and the wake up call.
* Added a warning in case an MLME Tx gets triggered while the device was
stopped.
* Used the rtnl to ensure the device cannot be stopped while an MLME
transmission is ongoing.
Changes in v1 since this series got extracted from a bigger change:
* Introduced a new atomic variable to know when the queue is actually
stopped. So far we only had an atomic to know when the queue was held
(indicates a transitioning state towards a stopped queue only) and
another atomic indicating if a transfer was still ongoing at this
point (used by the wait logic as a condition to wake up).
Miquel Raynal (11):
net: mac802154: Rename the synchronous xmit worker
net: mac802154: Rename the main tx_work struct
net: mac802154: Enhance the error path in the main tx helper
net: mac802154: Follow the count of ongoing transmissions
net: mac802154: Bring the ability to hold the transmit queue
net: mac802154: Create a hot tx path
net: mac802154: Introduce a helper to disable the queue
net: mac802154: Introduce a tx queue flushing mechanism
net: mac802154: Introduce a synchronous API for MLME commands
net: mac802154: Add a warning in the hot path
net: mac802154: Add a warning in the slow path
include/net/cfg802154.h | 9 ++-
include/net/mac802154.h | 27 -------
net/ieee802154/core.c | 3 +
net/mac802154/cfg.c | 4 +-
net/mac802154/ieee802154_i.h | 37 ++++++++-
net/mac802154/main.c | 2 +-
net/mac802154/tx.c | 147 +++++++++++++++++++++++++++++++----
net/mac802154/util.c | 71 +++++++++++++++--
8 files changed, 246 insertions(+), 54 deletions(-)
--
2.34.1
Powered by blists - more mailing lists