sctp: implement memory accounting on tx path
authorXin Long <lucien.xin@gmail.com>
Mon, 15 Apr 2019 09:15:06 +0000 (17:15 +0800)
committerDavid S. Miller <davem@davemloft.net>
Mon, 15 Apr 2019 20:36:51 +0000 (13:36 -0700)
commit1033990ac5b2ab6cee93734cb6d301aa3a35bcaa
tree7aed5c7a91b42d588c86e22b1d094e708b6b585f
parent93144b0ecde584e1e480abf45429ef47a5e02ac9
sctp: implement memory accounting on tx path

Now when sending packets, sk_mem_charge() and sk_mem_uncharge() have been
used to set sk_forward_alloc. We just need to call sk_wmem_schedule() to
check if the allocated should be raised, and call sk_mem_reclaim() to
check if the allocated should be reduced when it's under memory pressure.

If sk_wmem_schedule() returns false, which means no memory is allowed to
allocate, it will block and wait for memory to become available.

Note different from tcp, sctp wait_for_buf happens before allocating any
skb, so memory accounting check is done with the whole msg_len before it
too.

Reported-by: Matteo Croce <mcroce@redhat.com>
Tested-by: Matteo Croce <mcroce@redhat.com>
Acked-by: Neil Horman <nhorman@tuxdriver.com>
Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: Xin Long <lucien.xin@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sctp/socket.c