Skip to content

Commit

Permalink
sock: Code cleanup on __sk_mem_raise_allocated()
Browse files Browse the repository at this point in the history
Code cleanup for both better simplicity and readability.
No functional change intended.

Signed-off-by: Abel Wu <wuyun.abel@bytedance.com>
Acked-by: Shakeel Butt <shakeelb@google.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Link: https://lore.kernel.org/r/20231019120026.42215-1-wuyun.abel@bytedance.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
  • Loading branch information
Abel Wu authored and Paolo Abeni committed Oct 24, 2023
1 parent f6e1227 commit 2def8ff
Showing 1 changed file with 12 additions and 10 deletions.
22 changes: 12 additions & 10 deletions net/core/sock.c
Original file line number Diff line number Diff line change
Expand Up @@ -3039,17 +3039,19 @@ EXPORT_SYMBOL(sk_wait_data);
*/
int __sk_mem_raise_allocated(struct sock *sk, int size, int amt, int kind)
{
bool memcg_charge = mem_cgroup_sockets_enabled && sk->sk_memcg;
struct mem_cgroup *memcg = mem_cgroup_sockets_enabled ? sk->sk_memcg : NULL;
struct proto *prot = sk->sk_prot;
bool charged = true;
bool charged = false;
long allocated;

sk_memory_allocated_add(sk, amt);
allocated = sk_memory_allocated(sk);
if (memcg_charge &&
!(charged = mem_cgroup_charge_skmem(sk->sk_memcg, amt,
gfp_memcg_charge())))
goto suppress_allocation;

if (memcg) {
if (!mem_cgroup_charge_skmem(memcg, amt, gfp_memcg_charge()))
goto suppress_allocation;
charged = true;
}

/* Under limit. */
if (allocated <= sk_prot_mem_limits(sk, 0)) {
Expand Down Expand Up @@ -3104,8 +3106,8 @@ int __sk_mem_raise_allocated(struct sock *sk, int size, int amt, int kind)
*/
if (sk->sk_wmem_queued + size >= sk->sk_sndbuf) {
/* Force charge with __GFP_NOFAIL */
if (memcg_charge && !charged) {
mem_cgroup_charge_skmem(sk->sk_memcg, amt,
if (memcg && !charged) {
mem_cgroup_charge_skmem(memcg, amt,
gfp_memcg_charge() | __GFP_NOFAIL);
}
return 1;
Expand All @@ -3117,8 +3119,8 @@ int __sk_mem_raise_allocated(struct sock *sk, int size, int amt, int kind)

sk_memory_allocated_sub(sk, amt);

if (memcg_charge && charged)
mem_cgroup_uncharge_skmem(sk->sk_memcg, amt);
if (charged)
mem_cgroup_uncharge_skmem(memcg, amt);

return 0;
}
Expand Down

0 comments on commit 2def8ff

Please sign in to comment.