forked from Minki/linux
net/tls: fix encryption error checking
bpf_exec_tx_verdict() can return negative value for copied variable. In that case this value will be pushed back to caller and the real error code will be lost. Fix it using signed type and checking for positive value. Fixes:d10523d0b3
("net/tls: free the record on encryption error") Fixes:d3b18ad31f
("tls: add bpf support to sk_msg handling") Signed-off-by: Vadim Fedorenko <vfedorenko@novek.ru> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
04ba6b7dd8
commit
a7bff11f6f
@ -780,7 +780,7 @@ static int tls_push_record(struct sock *sk, int flags,
|
|||||||
|
|
||||||
static int bpf_exec_tx_verdict(struct sk_msg *msg, struct sock *sk,
|
static int bpf_exec_tx_verdict(struct sk_msg *msg, struct sock *sk,
|
||||||
bool full_record, u8 record_type,
|
bool full_record, u8 record_type,
|
||||||
size_t *copied, int flags)
|
ssize_t *copied, int flags)
|
||||||
{
|
{
|
||||||
struct tls_context *tls_ctx = tls_get_ctx(sk);
|
struct tls_context *tls_ctx = tls_get_ctx(sk);
|
||||||
struct tls_sw_context_tx *ctx = tls_sw_ctx_tx(tls_ctx);
|
struct tls_sw_context_tx *ctx = tls_sw_ctx_tx(tls_ctx);
|
||||||
@ -916,7 +916,8 @@ int tls_sw_sendmsg(struct sock *sk, struct msghdr *msg, size_t size)
|
|||||||
unsigned char record_type = TLS_RECORD_TYPE_DATA;
|
unsigned char record_type = TLS_RECORD_TYPE_DATA;
|
||||||
bool is_kvec = iov_iter_is_kvec(&msg->msg_iter);
|
bool is_kvec = iov_iter_is_kvec(&msg->msg_iter);
|
||||||
bool eor = !(msg->msg_flags & MSG_MORE);
|
bool eor = !(msg->msg_flags & MSG_MORE);
|
||||||
size_t try_to_copy, copied = 0;
|
size_t try_to_copy;
|
||||||
|
ssize_t copied = 0;
|
||||||
struct sk_msg *msg_pl, *msg_en;
|
struct sk_msg *msg_pl, *msg_en;
|
||||||
struct tls_rec *rec;
|
struct tls_rec *rec;
|
||||||
int required_size;
|
int required_size;
|
||||||
@ -1118,7 +1119,7 @@ send_end:
|
|||||||
|
|
||||||
release_sock(sk);
|
release_sock(sk);
|
||||||
mutex_unlock(&tls_ctx->tx_lock);
|
mutex_unlock(&tls_ctx->tx_lock);
|
||||||
return copied ? copied : ret;
|
return copied > 0 ? copied : ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tls_sw_do_sendpage(struct sock *sk, struct page *page,
|
static int tls_sw_do_sendpage(struct sock *sk, struct page *page,
|
||||||
@ -1132,7 +1133,7 @@ static int tls_sw_do_sendpage(struct sock *sk, struct page *page,
|
|||||||
struct sk_msg *msg_pl;
|
struct sk_msg *msg_pl;
|
||||||
struct tls_rec *rec;
|
struct tls_rec *rec;
|
||||||
int num_async = 0;
|
int num_async = 0;
|
||||||
size_t copied = 0;
|
ssize_t copied = 0;
|
||||||
bool full_record;
|
bool full_record;
|
||||||
int record_room;
|
int record_room;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@ -1234,7 +1235,7 @@ wait_for_memory:
|
|||||||
}
|
}
|
||||||
sendpage_end:
|
sendpage_end:
|
||||||
ret = sk_stream_error(sk, flags, ret);
|
ret = sk_stream_error(sk, flags, ret);
|
||||||
return copied ? copied : ret;
|
return copied > 0 ? copied : ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
int tls_sw_sendpage_locked(struct sock *sk, struct page *page,
|
int tls_sw_sendpage_locked(struct sock *sk, struct page *page,
|
||||||
|
Loading…
Reference in New Issue
Block a user