diff options
author | Alex Elder <elder@linaro.org> | 2022-09-06 12:19:42 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2022-09-09 11:45:25 +0100 |
commit | 019e37eaef97d99285390b6eb42410a54a5d6412 (patch) | |
tree | 44b0dce2f682ec745122d4e78f2a3ad1dea5d864 /drivers/net/ipa/gsi_trans.c | |
parent | e0e3406c60d7e5b004cc3059dea6c7574d26ca66 (diff) | |
download | linux-019e37eaef97d99285390b6eb42410a54a5d6412.tar.gz linux-019e37eaef97d99285390b6eb42410a54a5d6412.tar.bz2 linux-019e37eaef97d99285390b6eb42410a54a5d6412.zip |
net: ipa: don't have gsi_channel_update() return a value
If it finds no completed transactions, gsi_channel_trans_complete()
calls gsi_channel_update() to check hardware. If new transactions
have completed, gsi_channel_update() records that, then calls
gsi_channel_trans_complete() to return the first of those found.
This recursion won't go any further, but can be avoided if we
have gsi_channel_update() only be responsible for updating state
after accessing hardware.
Change gsi_channel_update() so it simply checks for and handles
new completions, without returning a value. If it needs to call
that function, have gsi_channel_trans_complete() determine whether
there are new transactions available after the update.
Signed-off-by: Alex Elder <elder@linaro.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ipa/gsi_trans.c')
-rw-r--r-- | drivers/net/ipa/gsi_trans.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/net/ipa/gsi_trans.c b/drivers/net/ipa/gsi_trans.c index 0b78ae904bac..03e54fc4376a 100644 --- a/drivers/net/ipa/gsi_trans.c +++ b/drivers/net/ipa/gsi_trans.c @@ -240,8 +240,11 @@ struct gsi_trans *gsi_channel_trans_complete(struct gsi_channel *channel) struct gsi_trans_info *trans_info = &channel->trans_info; u16 trans_id = trans_info->completed_id; - if (trans_id == trans_info->pending_id) - return gsi_channel_update(channel); + if (trans_id == trans_info->pending_id) { + gsi_channel_update(channel); + if (trans_id == trans_info->pending_id) + return NULL; + } return &trans_info->trans[trans_id %= channel->tre_count]; } |