diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2019-04-17 19:57:45 +0300 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2019-04-17 19:57:45 +0300 | 
| commit | 2a3a028fc61d03e80ac57091330eb514280bd5be (patch) | |
| tree | c0f98d752faa37fed4d11231f08d368dce120786 /net/rxrpc/sendmsg.c | |
| parent | 444fe991353987c1c9bc5ab1f903d01f1b4ad415 (diff) | |
| parent | e6986423d28362aafe64d3757bbbc493f2687f8f (diff) | |
| download | linux-2a3a028fc61d03e80ac57091330eb514280bd5be.tar.xz | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Pull networking fixes from David Miller:
 1) Handle init flow failures properly in iwlwifi driver, from Shahar S
    Matityahu.
 2) mac80211 TXQs need to be unscheduled on powersave start, from Felix
    Fietkau.
 3) SKB memory accounting fix in A-MDSU aggregation, from Felix Fietkau.
 4) Increase RCU lock hold time in mlx5 FPGA code, from Saeed Mahameed.
 5) Avoid checksum complete with XDP in mlx5, also from Saeed.
 6) Fix netdev feature clobbering in ibmvnic driver, from Thomas Falcon.
 7) Partial sent TLS record leak fix from Jakub Kicinski.
 8) Reject zero size iova range in vhost, from Jason Wang.
 9) Allow pending work to complete before clcsock release from Karsten
    Graul.
10) Fix XDP handling max MTU in thunderx, from Matteo Croce.
11) A lot of protocols look at the sa_family field of a sockaddr before
    validating it's length is large enough, from Tetsuo Handa.
12) Don't write to free'd pointer in qede ptp error path, from Colin Ian
    King.
13) Have to recompile IP options in ipv4_link_failure because it can be
    invoked from ARP, from Stephen Suryaputra.
14) Doorbell handling fixes in qed from Denis Bolotin.
15) Revert net-sysfs kobject register leak fix, it causes new problems.
    From Wang Hai.
16) Spectre v1 fix in ATM code, from Gustavo A. R. Silva.
17) Fix put of BROPT_VLAN_STATS_PER_PORT in bridging code, from Nikolay
    Aleksandrov.
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net: (111 commits)
  socket: fix compat SO_RCVTIMEO_NEW/SO_SNDTIMEO_NEW
  tcp: tcp_grow_window() needs to respect tcp_space()
  ocelot: Clean up stats update deferred work
  ocelot: Don't sleep in atomic context (irqs_disabled())
  net: bridge: fix netlink export of vlan_stats_per_port option
  qed: fix spelling mistake "faspath" -> "fastpath"
  tipc: set sysctl_tipc_rmem and named_timeout right range
  tipc: fix link established but not in session
  net: Fix missing meta data in skb with vlan packet
  net: atm: Fix potential Spectre v1 vulnerabilities
  net/core: work around section mismatch warning for ptp_classifier
  net: bridge: fix per-port af_packet sockets
  bnx2x: fix spelling mistake "dicline" -> "decline"
  route: Avoid crash from dereferencing NULL rt->from
  MAINTAINERS: normalize Woojung Huh's email address
  bonding: fix event handling for stacked bonds
  Revert "net-sysfs: Fix memory leak in netdev_register_kobject"
  rtnetlink: fix rtnl_valid_stats_req() nlmsg_len check
  qed: Fix the DORQ's attentions handling
  qed: Fix missing DORQ attentions
  ...
Diffstat (limited to 'net/rxrpc/sendmsg.c')
| -rw-r--r-- | net/rxrpc/sendmsg.c | 21 | 
1 files changed, 12 insertions, 9 deletions
| diff --git a/net/rxrpc/sendmsg.c b/net/rxrpc/sendmsg.c index 46c9312085b1..bec64deb7b0a 100644 --- a/net/rxrpc/sendmsg.c +++ b/net/rxrpc/sendmsg.c @@ -152,12 +152,13 @@ static void rxrpc_notify_end_tx(struct rxrpc_sock *rx, struct rxrpc_call *call,  }  /* - * Queue a DATA packet for transmission, set the resend timeout and send the - * packet immediately + * Queue a DATA packet for transmission, set the resend timeout and send + * the packet immediately.  Returns the error from rxrpc_send_data_packet() + * in case the caller wants to do something with it.   */ -static void rxrpc_queue_packet(struct rxrpc_sock *rx, struct rxrpc_call *call, -			       struct sk_buff *skb, bool last, -			       rxrpc_notify_end_tx_t notify_end_tx) +static int rxrpc_queue_packet(struct rxrpc_sock *rx, struct rxrpc_call *call, +			      struct sk_buff *skb, bool last, +			      rxrpc_notify_end_tx_t notify_end_tx)  {  	struct rxrpc_skb_priv *sp = rxrpc_skb(skb);  	unsigned long now; @@ -250,7 +251,8 @@ static void rxrpc_queue_packet(struct rxrpc_sock *rx, struct rxrpc_call *call,  out:  	rxrpc_free_skb(skb, rxrpc_skb_tx_freed); -	_leave(""); +	_leave(" = %d", ret); +	return ret;  }  /* @@ -423,9 +425,10 @@ static int rxrpc_send_data(struct rxrpc_sock *rx,  			if (ret < 0)  				goto out; -			rxrpc_queue_packet(rx, call, skb, -					   !msg_data_left(msg) && !more, -					   notify_end_tx); +			ret = rxrpc_queue_packet(rx, call, skb, +						 !msg_data_left(msg) && !more, +						 notify_end_tx); +			/* Should check for failure here */  			skb = NULL;  		}  	} while (msg_data_left(msg) > 0); | 
