diff options
author | David Howells <dhowells@redhat.com> | 2018-10-19 19:57:56 -0400 |
---|---|---|
committer | David Howells <dhowells@redhat.com> | 2018-10-23 19:41:07 -0400 |
commit | aa563d7bca6e882ec2bdae24603c8f016401a144 (patch) | |
tree | 874b10fc11da3178e4630f7a430e1b299d3b3806 /net/tls/tls_device.c | |
parent | 00e23707442a75b404392cef1405ab4fd498de6b (diff) |
iov_iter: Separate type from direction and use accessor functions
In the iov_iter struct, separate the iterator type from the iterator
direction and use accessor functions to access them in most places.
Convert a bunch of places to use switch-statements to access them rather
then chains of bitwise-AND statements. This makes it easier to add further
iterator types. Also, this can be more efficient as to implement a switch
of small contiguous integers, the compiler can use ~50% fewer compare
instructions than it has to use bitwise-and instructions.
Further, cease passing the iterator type into the iterator setup function.
The iterator function can set that itself. Only the direction is required.
Signed-off-by: David Howells <dhowells@redhat.com>
Diffstat (limited to 'net/tls/tls_device.c')
-rw-r--r-- | net/tls/tls_device.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/tls/tls_device.c b/net/tls/tls_device.c index 276edbc04f38..d753e362d2d9 100644 --- a/net/tls/tls_device.c +++ b/net/tls/tls_device.c | |||
@@ -489,7 +489,7 @@ int tls_device_sendpage(struct sock *sk, struct page *page, | |||
489 | 489 | ||
490 | iov.iov_base = kaddr + offset; | 490 | iov.iov_base = kaddr + offset; |
491 | iov.iov_len = size; | 491 | iov.iov_len = size; |
492 | iov_iter_kvec(&msg_iter, WRITE | ITER_KVEC, &iov, 1, size); | 492 | iov_iter_kvec(&msg_iter, WRITE, &iov, 1, size); |
493 | rc = tls_push_data(sk, &msg_iter, size, | 493 | rc = tls_push_data(sk, &msg_iter, size, |
494 | flags, TLS_RECORD_TYPE_DATA); | 494 | flags, TLS_RECORD_TYPE_DATA); |
495 | kunmap(page); | 495 | kunmap(page); |
@@ -538,7 +538,7 @@ static int tls_device_push_pending_record(struct sock *sk, int flags) | |||
538 | { | 538 | { |
539 | struct iov_iter msg_iter; | 539 | struct iov_iter msg_iter; |
540 | 540 | ||
541 | iov_iter_kvec(&msg_iter, WRITE | ITER_KVEC, NULL, 0, 0); | 541 | iov_iter_kvec(&msg_iter, WRITE, NULL, 0, 0); |
542 | return tls_push_data(sk, &msg_iter, 0, flags, TLS_RECORD_TYPE_DATA); | 542 | return tls_push_data(sk, &msg_iter, 0, flags, TLS_RECORD_TYPE_DATA); |
543 | } | 543 | } |
544 | 544 | ||