diff options
| author | 2007-11-10 22:08:30 -0800 | |
|---|---|---|
| committer | 2007-11-10 22:08:30 -0800 | |
| commit | 284b327be2f86cf751316ff344b6945e580e654f (patch) | |
| tree | 61a5e5b353be80e092795e357863509861a6a774 /net/core/dev.c | |
| parent | [AF_UNIX]: Convert socks to unix_socks in scan_inflight, not in callbacks (diff) | |
| download | wireguard-linux-284b327be2f86cf751316ff344b6945e580e654f.tar.xz wireguard-linux-284b327be2f86cf751316ff344b6945e580e654f.zip | |
[UNIX]: The unix_nr_socks limit can be exceeded
The unix_nr_socks value is limited with the 2 * get_max_files() value,
as seen from the unix_create1(). However, the check and the actual
increment are separated with the GFP_KERNEL allocation, so this limit
can be exceeded under a memory pressure - task may go to sleep freeing
the pages and some other task will be allowed to allocate a new sock
and so on and so forth.
So make the increment before the check (similar thing is done in the
sock_kmalloc) and go to kmalloc after this.
Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/dev.c')
0 files changed, 0 insertions, 0 deletions
