diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2018-08-15 15:04:25 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-08-15 15:04:25 -0700 | 
| commit | 9a76aba02a37718242d7cdc294f0a3901928aa57 (patch) | |
| tree | 2040d038f85d2120f21af83b0793efd5af1864e3 /fs/afs | |
| parent | 0a957467c5fd46142bc9c52758ffc552d4c5e2f7 (diff) | |
| parent | 26a1ccc6c117be8e33e0410fce8c5298b0015b99 (diff) | |
| download | linux-9a76aba02a37718242d7cdc294f0a3901928aa57.tar.bz2 | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-next
Pull networking updates from David Miller:
 "Highlights:
   - Gustavo A. R. Silva keeps working on the implicit switch fallthru
     changes.
   - Support 802.11ax High-Efficiency wireless in cfg80211 et al, From
     Luca Coelho.
   - Re-enable ASPM in r8169, from Kai-Heng Feng.
   - Add virtual XFRM interfaces, which avoids all of the limitations of
     existing IPSEC tunnels. From Steffen Klassert.
   - Convert GRO over to use a hash table, so that when we have many
     flows active we don't traverse a long list during accumluation.
   - Many new self tests for routing, TC, tunnels, etc. Too many
     contributors to mention them all, but I'm really happy to keep
     seeing this stuff.
   - Hardware timestamping support for dpaa_eth/fsl-fman from Yangbo Lu.
   - Lots of cleanups and fixes in L2TP code from Guillaume Nault.
   - Add IPSEC offload support to netdevsim, from Shannon Nelson.
   - Add support for slotting with non-uniform distribution to netem
     packet scheduler, from Yousuk Seung.
   - Add UDP GSO support to mlx5e, from Boris Pismenny.
   - Support offloading of Team LAG in NFP, from John Hurley.
   - Allow to configure TX queue selection based upon RX queue, from
     Amritha Nambiar.
   - Support ethtool ring size configuration in aquantia, from Anton
     Mikaev.
   - Support DSCP and flowlabel per-transport in SCTP, from Xin Long.
   - Support list based batching and stack traversal of SKBs, this is
     very exciting work. From Edward Cree.
   - Busyloop optimizations in vhost_net, from Toshiaki Makita.
   - Introduce the ETF qdisc, which allows time based transmissions. IGB
     can offload this in hardware. From Vinicius Costa Gomes.
   - Add parameter support to devlink, from Moshe Shemesh.
   - Several multiplication and division optimizations for BPF JIT in
     nfp driver, from Jiong Wang.
   - Lots of prepatory work to make more of the packet scheduler layer
     lockless, when possible, from Vlad Buslov.
   - Add ACK filter and NAT awareness to sch_cake packet scheduler, from
     Toke Høiland-Jørgensen.
   - Support regions and region snapshots in devlink, from Alex Vesker.
   - Allow to attach XDP programs to both HW and SW at the same time on
     a given device, with initial support in nfp. From Jakub Kicinski.
   - Add TLS RX offload and support in mlx5, from Ilya Lesokhin.
   - Use PHYLIB in r8169 driver, from Heiner Kallweit.
   - All sorts of changes to support Spectrum 2 in mlxsw driver, from
     Ido Schimmel.
   - PTP support in mv88e6xxx DSA driver, from Andrew Lunn.
   - Make TCP_USER_TIMEOUT socket option more accurate, from Jon
     Maxwell.
   - Support for templates in packet scheduler classifier, from Jiri
     Pirko.
   - IPV6 support in RDS, from Ka-Cheong Poon.
   - Native tproxy support in nf_tables, from Máté Eckl.
   - Maintain IP fragment queue in an rbtree, but optimize properly for
     in-order frags. From Peter Oskolkov.
   - Improvde handling of ACKs on hole repairs, from Yuchung Cheng"
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-next: (1996 commits)
  bpf: test: fix spelling mistake "REUSEEPORT" -> "REUSEPORT"
  hv/netvsc: Fix NULL dereference at single queue mode fallback
  net: filter: mark expected switch fall-through
  xen-netfront: fix warn message as irq device name has '/'
  cxgb4: Add new T5 PCI device ids 0x50af and 0x50b0
  net: dsa: mv88e6xxx: missing unlock on error path
  rds: fix building with IPV6=m
  inet/connection_sock: prefer _THIS_IP_ to current_text_addr
  net: dsa: mv88e6xxx: bitwise vs logical bug
  net: sock_diag: Fix spectre v1 gadget in __sock_diag_cmd()
  ieee802154: hwsim: using right kind of iteration
  net: hns3: Add vlan filter setting by ethtool command -K
  net: hns3: Set tx ring' tc info when netdev is up
  net: hns3: Remove tx ring BD len register in hns3_enet
  net: hns3: Fix desc num set to default when setting channel
  net: hns3: Fix for phy link issue when using marvell phy driver
  net: hns3: Fix for information of phydev lost problem when down/up
  net: hns3: Fix for command format parsing error in hclge_is_all_function_id_zero
  net: hns3: Add support for serdes loopback selftest
  bnxt_en: take coredump_record structure off stack
  ...
Diffstat (limited to 'fs/afs')
| -rw-r--r-- | fs/afs/rxrpc.c | 28 | 
1 files changed, 17 insertions, 11 deletions
| diff --git a/fs/afs/rxrpc.c b/fs/afs/rxrpc.c index 183cc5418722..35f2ae30f31f 100644 --- a/fs/afs/rxrpc.c +++ b/fs/afs/rxrpc.c @@ -346,7 +346,6 @@ long afs_make_call(struct afs_addr_cursor *ac, struct afs_call *call,  	struct rxrpc_call *rxcall;  	struct msghdr msg;  	struct kvec iov[1]; -	size_t offset;  	s64 tx_total_len;  	int ret; @@ -433,10 +432,10 @@ error_do_abort:  		rxrpc_kernel_abort_call(call->net->socket, rxcall,  					RX_USER_ABORT, ret, "KSD");  	} else { -		offset = 0; -		rxrpc_kernel_recv_data(call->net->socket, rxcall, NULL, -				       0, &offset, false, &call->abort_code, -				       &call->service_id); +		iov_iter_kvec(&msg.msg_iter, READ | ITER_KVEC, NULL, 0, 0); +		rxrpc_kernel_recv_data(call->net->socket, rxcall, +				       &msg.msg_iter, false, +				       &call->abort_code, &call->service_id);  		ac->abort_code = call->abort_code;  		ac->responded = true;  	} @@ -467,13 +466,14 @@ static void afs_deliver_to_call(struct afs_call *call)  	       state == AFS_CALL_SV_AWAIT_ACK  	       ) {  		if (state == AFS_CALL_SV_AWAIT_ACK) { -			size_t offset = 0; +			struct iov_iter iter; + +			iov_iter_kvec(&iter, READ | ITER_KVEC, NULL, 0, 0);  			ret = rxrpc_kernel_recv_data(call->net->socket, -						     call->rxcall, -						     NULL, 0, &offset, false, +						     call->rxcall, &iter, false,  						     &remote_abort,  						     &call->service_id); -			trace_afs_recv_data(call, 0, offset, false, ret); +			trace_afs_recv_data(call, 0, 0, false, ret);  			if (ret == -EINPROGRESS || ret == -EAGAIN)  				return; @@ -894,6 +894,8 @@ int afs_extract_data(struct afs_call *call, void *buf, size_t count,  		     bool want_more)  {  	struct afs_net *net = call->net; +	struct iov_iter iter; +	struct kvec iov;  	enum afs_call_state state;  	u32 remote_abort = 0;  	int ret; @@ -903,10 +905,14 @@ int afs_extract_data(struct afs_call *call, void *buf, size_t count,  	ASSERTCMP(call->offset, <=, count); -	ret = rxrpc_kernel_recv_data(net->socket, call->rxcall, -				     buf, count, &call->offset, +	iov.iov_base = buf + call->offset; +	iov.iov_len = count - call->offset; +	iov_iter_kvec(&iter, ITER_KVEC | READ, &iov, 1, count - call->offset); + +	ret = rxrpc_kernel_recv_data(net->socket, call->rxcall, &iter,  				     want_more, &remote_abort,  				     &call->service_id); +	call->offset += (count - call->offset) - iov_iter_count(&iter);  	trace_afs_recv_data(call, count, call->offset, want_more, ret);  	if (ret == 0 || ret == -EAGAIN)  		return ret; |