之前看这个函数里有一个地方没有看懂,代码如下:
cpp
if (sk_has_memory_pressure(sk)) {
int alloc;
if (!sk_under_memory_pressure(sk))
return 1;
alloc = sk_sockets_allocated_read_positive(sk);
if (sk_prot_mem_limits(sk, 2) > alloc *
sk_mem_pages(sk->sk_wmem_queued +
atomic_read(&sk->sk_rmem_alloc) +
sk->sk_forward_alloc))
return 1;
}
今天在网上找了一下,搜到下面的链接,里面有一个解释是:
https://lore.kernel.org/all/20231019120026.42215-2-wuyun.abel@bytedance.com/
Try to be fair among all the sockets under global pressure by allowing the ones that below average usage to raise.
尝试在全局压力下的所有套接字之间保持一个公平,允许低于平均使用率的套接字升高,高使用内存的socket不让申请内存。