* [PATCH v6 2/3] kernel/fork.c: get estimated free pages by memblock api
2024-08-08 0:14 [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages() Wei Yang
@ 2024-08-08 0:14 ` Wei Yang
2024-08-08 8:54 ` David Hildenbrand
2024-08-08 0:14 ` [PATCH v6 3/3] s390/mm: " Wei Yang
` (2 subsequent siblings)
3 siblings, 1 reply; 9+ messages in thread
From: Wei Yang @ 2024-08-08 0:14 UTC (permalink / raw)
To: agordeev, gerald.schaefer, hca, rppt, akpm, brauner, oleg
Cc: linux-s390, linux-kernel, linux-mm, Wei Yang, David Hildenbrand
Instead of getting estimated free pages from memblock directly, we have
introduced an API, memblock_estimated_nr_free_pages(), which is more
friendly for users.
Just replace it with new API, no functional change.
Signed-off-by: Wei Yang <richard.weiyang@gmail.com>
CC: Mike Rapoport (IBM) <rppt@kernel.org>
CC: David Hildenbrand <david@redhat.com>
CC: Oleg Nesterov <oleg@redhat.com>
---
kernel/fork.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/kernel/fork.c b/kernel/fork.c
index cc760491f201..d99f148d818b 100644
--- a/kernel/fork.c
+++ b/kernel/fork.c
@@ -997,7 +997,7 @@ void __init __weak arch_task_cache_init(void) { }
static void __init set_max_threads(unsigned int max_threads_suggested)
{
u64 threads;
- unsigned long nr_pages = PHYS_PFN(memblock_phys_mem_size() - memblock_reserved_size());
+ unsigned long nr_pages = memblock_estimated_nr_free_pages();
/*
* The number of threads shall be limited such that the thread
--
2.34.1
^ permalink raw reply related [flat|nested] 9+ messages in thread* Re: [PATCH v6 2/3] kernel/fork.c: get estimated free pages by memblock api
2024-08-08 0:14 ` [PATCH v6 2/3] kernel/fork.c: get estimated free pages by memblock api Wei Yang
@ 2024-08-08 8:54 ` David Hildenbrand
0 siblings, 0 replies; 9+ messages in thread
From: David Hildenbrand @ 2024-08-08 8:54 UTC (permalink / raw)
To: Wei Yang, agordeev, gerald.schaefer, hca, rppt, akpm, brauner,
oleg
Cc: linux-s390, linux-kernel, linux-mm
On 08.08.24 02:14, Wei Yang wrote:
> Instead of getting estimated free pages from memblock directly, we have
> introduced an API, memblock_estimated_nr_free_pages(), which is more
> friendly for users.
>
> Just replace it with new API, no functional change.
>
> Signed-off-by: Wei Yang <richard.weiyang@gmail.com>
> CC: Mike Rapoport (IBM) <rppt@kernel.org>
> CC: David Hildenbrand <david@redhat.com>
> CC: Oleg Nesterov <oleg@redhat.com>
> ---
Acked-by: David Hildenbrand <david@redhat.com>
--
Cheers,
David / dhildenb
^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH v6 3/3] s390/mm: get estimated free pages by memblock api
2024-08-08 0:14 [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages() Wei Yang
2024-08-08 0:14 ` [PATCH v6 2/3] kernel/fork.c: get estimated free pages by memblock api Wei Yang
@ 2024-08-08 0:14 ` Wei Yang
2024-08-08 8:54 ` David Hildenbrand
2024-08-08 10:06 ` [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages() Alexander Gordeev
2024-08-11 16:38 ` Mike Rapoport
3 siblings, 1 reply; 9+ messages in thread
From: Wei Yang @ 2024-08-08 0:14 UTC (permalink / raw)
To: agordeev, gerald.schaefer, hca, rppt, akpm, brauner, oleg
Cc: linux-s390, linux-kernel, linux-mm, Wei Yang, David Hildenbrand
Instead of getting estimated free pages from memblock directly, we have
introduced an API, memblock_estimated_nr_free_pages(), which is more
friendly for users.
Just replace it with new API, no functional change.
Signed-off-by: Wei Yang <richard.weiyang@gmail.com>
CC: Mike Rapoport (IBM) <rppt@kernel.org>
CC: David Hildenbrand <david@redhat.com>
---
arch/s390/mm/init.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/arch/s390/mm/init.c b/arch/s390/mm/init.c
index e3d258f9e726..651344206294 100644
--- a/arch/s390/mm/init.c
+++ b/arch/s390/mm/init.c
@@ -62,7 +62,7 @@ EXPORT_SYMBOL(zero_page_mask);
static void __init setup_zero_pages(void)
{
- unsigned long total_pages = PHYS_PFN(memblock_phys_mem_size() - memblock_reserved_size());
+ unsigned long total_pages = memblock_estimated_nr_free_pages();
unsigned int order;
struct page *page;
int i;
--
2.34.1
^ permalink raw reply related [flat|nested] 9+ messages in thread* Re: [PATCH v6 3/3] s390/mm: get estimated free pages by memblock api
2024-08-08 0:14 ` [PATCH v6 3/3] s390/mm: " Wei Yang
@ 2024-08-08 8:54 ` David Hildenbrand
0 siblings, 0 replies; 9+ messages in thread
From: David Hildenbrand @ 2024-08-08 8:54 UTC (permalink / raw)
To: Wei Yang, agordeev, gerald.schaefer, hca, rppt, akpm, brauner,
oleg
Cc: linux-s390, linux-kernel, linux-mm
On 08.08.24 02:14, Wei Yang wrote:
> Instead of getting estimated free pages from memblock directly, we have
> introduced an API, memblock_estimated_nr_free_pages(), which is more
> friendly for users.
>
> Just replace it with new API, no functional change.
>
> Signed-off-by: Wei Yang <richard.weiyang@gmail.com>
> CC: Mike Rapoport (IBM) <rppt@kernel.org>
> CC: David Hildenbrand <david@redhat.com>
> ---
Acked-by: David Hildenbrand <david@redhat.com>
--
Cheers,
David / dhildenb
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages()
2024-08-08 0:14 [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages() Wei Yang
2024-08-08 0:14 ` [PATCH v6 2/3] kernel/fork.c: get estimated free pages by memblock api Wei Yang
2024-08-08 0:14 ` [PATCH v6 3/3] s390/mm: " Wei Yang
@ 2024-08-08 10:06 ` Alexander Gordeev
2024-08-08 14:24 ` Wei Yang
2024-08-11 16:38 ` Mike Rapoport
3 siblings, 1 reply; 9+ messages in thread
From: Alexander Gordeev @ 2024-08-08 10:06 UTC (permalink / raw)
To: Wei Yang
Cc: gerald.schaefer, hca, rppt, akpm, brauner, oleg, linux-s390,
linux-kernel, linux-mm, David Hildenbrand
On Thu, Aug 08, 2024 at 12:14:13AM +0000, Wei Yang wrote:
Hi Wei,
...
> + * Return:
> + * An estimated number of free pages from memblock point of view.
> + */
> +unsigned long __init memblock_estimated_nr_free_pages(void)
> +{
> + return PHYS_PFN(memblock_phys_mem_size() - memblock_reserved_size());
> +}
This could possibly be short on up to two pages due to lack of alignment.
The current uses are okay, but since you make it generic it probably matters.
Also, the returned value is not an estimation. Meaning the function name
is rather unfortunate AFAICT.
> +#define PHYS_PFN(x) ((unsigned long)((x) >> PAGE_SHIFT))
Thanks!
^ permalink raw reply [flat|nested] 9+ messages in thread* Re: [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages()
2024-08-08 10:06 ` [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages() Alexander Gordeev
@ 2024-08-08 14:24 ` Wei Yang
2024-08-08 16:10 ` Alexander Gordeev
0 siblings, 1 reply; 9+ messages in thread
From: Wei Yang @ 2024-08-08 14:24 UTC (permalink / raw)
To: Alexander Gordeev
Cc: Wei Yang, gerald.schaefer, hca, rppt, akpm, brauner, oleg,
linux-s390, linux-kernel, linux-mm, David Hildenbrand
On Thu, Aug 08, 2024 at 12:06:38PM +0200, Alexander Gordeev wrote:
>On Thu, Aug 08, 2024 at 12:14:13AM +0000, Wei Yang wrote:
>
>Hi Wei,
>
>...
>> + * Return:
>> + * An estimated number of free pages from memblock point of view.
>> + */
>> +unsigned long __init memblock_estimated_nr_free_pages(void)
>> +{
>> + return PHYS_PFN(memblock_phys_mem_size() - memblock_reserved_size());
>> +}
>
>This could possibly be short on up to two pages due to lack of alignment.
>The current uses are okay, but since you make it generic it probably matters.
>
I don't follow, would you mind giving more detail?
>Also, the returned value is not an estimation. Meaning the function name
>is rather unfortunate AFAICT.
From my point of view, this is an estimation for two reasons:
* value from memblock_xxx is not page size aligned
* reserved memory maybe released during boot stage
It is not that easy to get the exact number of free pages here. Do I miss
something?
>
>> +#define PHYS_PFN(x) ((unsigned long)((x) >> PAGE_SHIFT))
>
>Thanks!
--
Wei Yang
Help you, Help me
^ permalink raw reply [flat|nested] 9+ messages in thread* Re: [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages()
2024-08-08 14:24 ` Wei Yang
@ 2024-08-08 16:10 ` Alexander Gordeev
0 siblings, 0 replies; 9+ messages in thread
From: Alexander Gordeev @ 2024-08-08 16:10 UTC (permalink / raw)
To: Wei Yang
Cc: gerald.schaefer, hca, rppt, akpm, brauner, oleg, linux-s390,
linux-kernel, linux-mm, David Hildenbrand
On Thu, Aug 08, 2024 at 02:24:05PM +0000, Wei Yang wrote:
> >> + * An estimated number of free pages from memblock point of view.
> >> + */
> >> +unsigned long __init memblock_estimated_nr_free_pages(void)
> >> +{
> >> + return PHYS_PFN(memblock_phys_mem_size() - memblock_reserved_size());
> >> +}
> >
> >This could possibly be short on up to two pages due to lack of alignment.
> >The current uses are okay, but since you make it generic it probably matters.
> >
>
> I don't follow, would you mind giving more detail?
memblock_estimated_nr_free_pages() returns number of pages, not bytes.
Yet, both memblock_phys_mem_size() and memblock_reserved_size() return
a value which is not aligned on PAGE_SIZE. Therefore, the result of
PHYS_PFN() applied to the difference between the two functions might
be short on one (two?) page(s).
> >Also, the returned value is not an estimation. Meaning the function name
> >is rather unfortunate AFAICT.
>
> From my point of view, this is an estimation for two reasons:
>
> * value from memblock_xxx is not page size aligned
> * reserved memory maybe released during boot stage
>
> It is not that easy to get the exact number of free pages here. Do I miss
> something?
No, with this reasoning it makes sense to me.
> --
> Wei Yang
> Help you, Help me
Thank you for the clarification!
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages()
2024-08-08 0:14 [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages() Wei Yang
` (2 preceding siblings ...)
2024-08-08 10:06 ` [PATCH v6 1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages() Alexander Gordeev
@ 2024-08-11 16:38 ` Mike Rapoport
3 siblings, 0 replies; 9+ messages in thread
From: Mike Rapoport @ 2024-08-11 16:38 UTC (permalink / raw)
To: agordeev, gerald.schaefer, hca, akpm, brauner, oleg, Wei Yang
Cc: Mike Rapoport, linux-s390, linux-kernel, linux-mm,
David Hildenbrand
From: Mike Rapoport (Microsoft) <rppt@kernel.org>
On Thu, 08 Aug 2024 00:14:13 +0000, Wei Yang wrote:
> During bootup, system may need the number of free pages in the whole system
> to do some calculation before all pages are freed to buddy system. Usually
> this number is get from totalram_pages(). Since we plan to move the free
> pages accounting in __free_pages_core(), this value may not represent
> total free pages at the early stage, especially when
> CONFIG_DEFERRED_STRUCT_PAGE_INIT is enabled.
>
> [...]
Applied to for-next branch of memblock.git tree, thanks!
[1/3] mm/memblock: introduce a new helper memblock_estimated_nr_free_pages()
commit: d0f8a8973f265f6a276f99d091af99edfb2b87de
[2/3] kernel/fork.c: get estimated free pages by memblock api
commit: 0910bf0ef85c5404aac94394cb31e076e4eb03f1
[3/3] s390/mm: get estimated free pages by memblock api
commit: cb088e38aab4c7e9ce711c18c66e851c8f4227bb
tree: https://git.kernel.org/pub/scm/linux/kernel/git/rppt/memblock
branch: for-next
--
Sincerely yours,
Mike.
^ permalink raw reply [flat|nested] 9+ messages in thread