Skip to content

Commit

Permalink
net: tcp_memcontrol: remove dead per-memcg count of allocated sockets
Browse files Browse the repository at this point in the history
The number of allocated sockets is used for calculations in the soft
limit phase, where packets are accepted but the socket is under memory
pressure.
 Since there is no soft limit phase in tcp_memcontrol, and memory
pressure is only entered when packets are already dropped, this is
actually dead code.  Remove it.

As this is the last user of parent_cg_proto(), remove that too.

Signed-off-by: Johannes Weiner <[email protected]>
Acked-by: David S. Miller <[email protected]>
Reviewed-by: Vladimir Davydov <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
  • Loading branch information
hnaz authored and torvalds committed Jan 15, 2016
1 parent 3d596f7 commit af95d7d
Show file tree
Hide file tree
Showing 3 changed files with 3 additions and 40 deletions.
1 change: 0 additions & 1 deletion include/linux/memcontrol.h
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,6 @@ enum mem_cgroup_events_target {

struct cg_proto {
struct page_counter memory_allocated; /* Current allocated memory. */
struct percpu_counter sockets_allocated; /* Current number of sockets. */
int memory_pressure;
bool active;
long sysctl_mem[3];
Expand Down
39 changes: 3 additions & 36 deletions include/net/sock.h
Original file line number Diff line number Diff line change
Expand Up @@ -1098,19 +1098,9 @@ static inline void sk_refcnt_debug_release(const struct sock *sk)

#if defined(CONFIG_MEMCG_KMEM) && defined(CONFIG_NET)
extern struct static_key memcg_socket_limit_enabled;
static inline struct cg_proto *parent_cg_proto(struct proto *proto,
struct cg_proto *cg_proto)
{
return proto->proto_cgroup(parent_mem_cgroup(cg_proto->memcg));
}
#define mem_cgroup_sockets_enabled static_key_false(&memcg_socket_limit_enabled)
#else
#define mem_cgroup_sockets_enabled 0
static inline struct cg_proto *parent_cg_proto(struct proto *proto,
struct cg_proto *cg_proto)
{
return NULL;
}
#endif

static inline bool sk_stream_memory_free(const struct sock *sk)
Expand Down Expand Up @@ -1236,41 +1226,18 @@ sk_memory_allocated_sub(struct sock *sk, int amt)

static inline void sk_sockets_allocated_dec(struct sock *sk)
{
struct proto *prot = sk->sk_prot;

if (mem_cgroup_sockets_enabled && sk->sk_cgrp) {
struct cg_proto *cg_proto = sk->sk_cgrp;

for (; cg_proto; cg_proto = parent_cg_proto(prot, cg_proto))
percpu_counter_dec(&cg_proto->sockets_allocated);
}

percpu_counter_dec(prot->sockets_allocated);
percpu_counter_dec(sk->sk_prot->sockets_allocated);
}

static inline void sk_sockets_allocated_inc(struct sock *sk)
{
struct proto *prot = sk->sk_prot;

if (mem_cgroup_sockets_enabled && sk->sk_cgrp) {
struct cg_proto *cg_proto = sk->sk_cgrp;

for (; cg_proto; cg_proto = parent_cg_proto(prot, cg_proto))
percpu_counter_inc(&cg_proto->sockets_allocated);
}

percpu_counter_inc(prot->sockets_allocated);
percpu_counter_inc(sk->sk_prot->sockets_allocated);
}

static inline int
sk_sockets_allocated_read_positive(struct sock *sk)
{
struct proto *prot = sk->sk_prot;

if (mem_cgroup_sockets_enabled && sk->sk_cgrp)
return percpu_counter_read_positive(&sk->sk_cgrp->sockets_allocated);

return percpu_counter_read_positive(prot->sockets_allocated);
return percpu_counter_read_positive(sk->sk_prot->sockets_allocated);
}

static inline int
Expand Down
3 changes: 0 additions & 3 deletions net/ipv4/tcp_memcontrol.c
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@ int tcp_init_cgroup(struct mem_cgroup *memcg, struct cgroup_subsys *ss)
counter_parent = &parent_cg->memory_allocated;

page_counter_init(&cg_proto->memory_allocated, counter_parent);
percpu_counter_init(&cg_proto->sockets_allocated, 0, GFP_KERNEL);

return 0;
}
Expand All @@ -46,8 +45,6 @@ void tcp_destroy_cgroup(struct mem_cgroup *memcg)
if (!cg_proto)
return;

percpu_counter_destroy(&cg_proto->sockets_allocated);

if (cg_proto->active)
static_key_slow_dec(&memcg_socket_limit_enabled);

Expand Down

0 comments on commit af95d7d

Please sign in to comment.