Re: [PATCH] Hugetlb: stop race when reading proc meminfo

From: Nish Aravamudan
Date: Wed Jul 02 2008 - 18:51:57 EST


On 6/19/08, Eric Paris <eparis@xxxxxxxxxx> wrote:
> minor nit that hugetlb_report_{,node_}meminfo() does not lock the
> reading of nr_huge_pages, free_huge_pages, and friends so this is not an
> atomic set of information put into the buffer. If /proc/meminfo is read
> while the number of hugetlb pages is in flux it is possible to get
> incorrect output such as:
>
> HugePages_Total: 7
> HugePages_Free: 8
> HugePages_Rsvd: 0
> Hugepagesize: 4096 kB
>
> (test available at https://bugzilla.redhat.com/attachment.cgi?id=309864)
>
> With the patch we beat on a number of boxes for hours with the above
> test and saw no inconsistencies in the meminfo output.
>
> Signed-off-by: Eric Paris <eparis@xxxxxxxxxx>

While I understand the spirit of this patch, I'm not sure it's really
necessary. We've never bothered locking the output in the proc file
before because the information is inherently racy. It only gives you a
view of what was...if any application tries to make a decision based
upon that information (unless it has global control of the system, or
is a testcase, arguably), then it is already racy -- that is, the
numbers you read at one point in time have no bearing on whether those
pages will actually be free/available, etc when you actually need
them.

That being said, I don't feel to strongly about it. Just seems like it
might be unnecessary for an interface we know not to be fully accurate
to begin with, but maybe consistency is worth a bit of extra locking.

That actually also leads me to wonder if maybe the locking is not
there currently to avoid letting readers of proc files from blocking
users of hugepages?

Thanks,
Nish
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/