summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJakub Kicinski <jakub.kicinski@netronome.com>2019-11-05 17:24:34 -0500
committerDavid S. Miller <davem@davemloft.net>2019-11-06 20:33:32 -0500
commit02b1fa07bb58f5d1f349b5b09eb936739a7b20fc (patch)
tree7cad23cdb54a207b0864e45218995ce047112e3c
parent17fdd7638cb687cd7f15a48545f25d738f0101e0 (diff)
net/tls: don't pay attention to sk_write_pending when pushing partial records
sk_write_pending being not zero does not guarantee that partial record will be pushed. If the thread waiting for memory times out the pending record may get stuck. In case of tls_device there is no path where parial record is set and writer present in the first place. Partial record is set only in tls_push_sg() and tls_push_sg() will return an error immediately. All tls_device callers of tls_push_sg() will return (and not wait for memory) if it failed. Fixes: a42055e8d2c3 ("net/tls: Add support for async encryption of records for performance") Signed-off-by: Jakub Kicinski <jakub.kicinski@netronome.com> Reviewed-by: Simon Horman <simon.horman@netronome.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/tls/tls_device.c4
-rw-r--r--net/tls/tls_sw.c9
2 files changed, 6 insertions, 7 deletions
diff --git a/net/tls/tls_device.c b/net/tls/tls_device.c
index f959487c5cd1..5a3715ddc592 100644
--- a/net/tls/tls_device.c
+++ b/net/tls/tls_device.c
@@ -623,9 +623,11 @@ static int tls_device_push_pending_record(struct sock *sk, int flags)
623 623
624void tls_device_write_space(struct sock *sk, struct tls_context *ctx) 624void tls_device_write_space(struct sock *sk, struct tls_context *ctx)
625{ 625{
626 if (!sk->sk_write_pending && tls_is_partially_sent_record(ctx)) { 626 if (tls_is_partially_sent_record(ctx)) {
627 gfp_t sk_allocation = sk->sk_allocation; 627 gfp_t sk_allocation = sk->sk_allocation;
628 628
629 WARN_ON_ONCE(sk->sk_write_pending);
630
629 sk->sk_allocation = GFP_ATOMIC; 631 sk->sk_allocation = GFP_ATOMIC;
630 tls_push_partial_record(sk, ctx, 632 tls_push_partial_record(sk, ctx,
631 MSG_DONTWAIT | MSG_NOSIGNAL | 633 MSG_DONTWAIT | MSG_NOSIGNAL |
diff --git a/net/tls/tls_sw.c b/net/tls/tls_sw.c
index c2b5e0d2ba1a..e155b792df0b 100644
--- a/net/tls/tls_sw.c
+++ b/net/tls/tls_sw.c
@@ -2180,12 +2180,9 @@ void tls_sw_write_space(struct sock *sk, struct tls_context *ctx)
2180 struct tls_sw_context_tx *tx_ctx = tls_sw_ctx_tx(ctx); 2180 struct tls_sw_context_tx *tx_ctx = tls_sw_ctx_tx(ctx);
2181 2181
2182 /* Schedule the transmission if tx list is ready */ 2182 /* Schedule the transmission if tx list is ready */
2183 if (is_tx_ready(tx_ctx) && !sk->sk_write_pending) { 2183 if (is_tx_ready(tx_ctx) &&
2184 /* Schedule the transmission */ 2184 !test_and_set_bit(BIT_TX_SCHEDULED, &tx_ctx->tx_bitmask))
2185 if (!test_and_set_bit(BIT_TX_SCHEDULED, 2185 schedule_delayed_work(&tx_ctx->tx_work.work, 0);
2186 &tx_ctx->tx_bitmask))
2187 schedule_delayed_work(&tx_ctx->tx_work.work, 0);
2188 }
2189} 2186}
2190 2187
2191void tls_sw_strparser_arm(struct sock *sk, struct tls_context *tls_ctx) 2188void tls_sw_strparser_arm(struct sock *sk, struct tls_context *tls_ctx)