On Fri 09-08-19 16:54:43, Yang Shi wrote:
[...]
On 8/9/19 11:26 AM, Yang Shi wrote:
On 8/9/19 11:02 AM, Michal Hocko wrote:
Yes, changing NR_ANON_THPS semantic sounds like a bad idea. LetBy double checking what NR_ANON_THPS really means,I have to study the code some more but is there any reason why thoseI think we could keep those pages accounted for NR_ANON_THPS since they
pages are not accounted as proper THPs anymore? Sure they are partially
unmaped but they are still THPs so why cannot we keep them accounted
like that. Having a new counter to reflect that sounds like papering
over the problem to me. But as I've said I might be missing something
important here.
are still THP although they are unmapped as you mentioned if we just
want to fix the improper accounting.
Documentation/filesystems/proc.txt says "Non-file backed huge pages mapped
into userspace page tables". Then it makes some sense to dec NR_ANON_THPS
when removing rmap even though they are still THPs.
I don't think we would like to change the definition, if so a new counter
may make more sense.
me try whether I understand the problem. So we have some THP in
limbo waiting for them to be split and unmapped parts to be freed,
right? I can see that page_remove_anon_compound_rmap does correctly
decrement NR_ANON_MAPPED for sub pages that are no longer mapped by
anybody. LRU pages seem to be accounted properly as well. As you've
said NR_ANON_THPS reflects the number of THPs mapped and that should be
reflecting the reality already IIUC.
So the only problem seems to be that deferred THP might aggregate a lot
of immediately freeable memory (if none of the subpages are mapped) and
that can confuse MemAvailable because it doesn't know about the fact.
Has an skewed counter resulted in a user observable behavior/failures?
I can see that memcg rss size was the primary problem David was looking
at. But MemAvailable will not help with that, right? Moreover is
accounting the full THP correct? What if subpages are still mapped?