Michal Hocko <mhocko@xxxxxxxxxx> writes: > > Could you be more explicit about _why_ we need to remove this tunable? > I am not saying I disagree, the removal simplifies the code but I do not > really see any justification here. It's an arbitrary scaling limit on the how many mappings the process has. The more memory you have the bigger a problem it is. We've ran into this problem too on larger systems. The reason the limit was there originally because it allows a DoS attack against the kernel by filling all unswappable memory up with VMAs. The old limit was designed for much smaller systems than we have today. There needs to be some limit, but it should be on the number of memory pinned by the VMAs, and needs to scale with the available memory, so that large systems are not penalized. Unfortunately just making it part of the existing mlock limit could break some existing setups which max out the mlock limit with something else. Maybe we need a new rlimit for this? -Andi