linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] mm: numa_memblks: Identify the accurate NUMA ID of CFMW
@ 2025-12-30  9:27 Cui Chao
  2025-12-30 15:18 ` Mike Rapoport
  0 siblings, 1 reply; 5+ messages in thread
From: Cui Chao @ 2025-12-30  9:27 UTC (permalink / raw)
  To: Andrew Morton
  Cc: Joanthan Cameron, Mike Rapoport, wangyinfeng, linux-mm, linux-kernel

In some physical memory layout designs, the address space of CFMW
resides between multiple segments of system memory belonging to
the same NUMA node. In numa_cleanup_meminfo, these multiple segments
of system memory are merged into a larger numa_memblk. When
identifying which NUMA node the CFMW belongs to, it may be incorrectly
assigned to the NUMA node of the merged system memory. To address this
scenario, accurately identifying the correct NUMA node can be achieved
by checking whether the region belongs to both numa_meminfo and
numa_reserved_meminfo.

Signed-off-by: Cui Chao <cuichao1753@phytium.com.cn>
---
 mm/numa_memblks.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

diff --git a/mm/numa_memblks.c b/mm/numa_memblks.c
index 5b009a9cd8b4..1ef037f0e0e0 100644
--- a/mm/numa_memblks.c
+++ b/mm/numa_memblks.c
@@ -573,7 +573,8 @@ int phys_to_target_node(u64 start)
 	 * Prefer online nodes, but if reserved memory might be
 	 * hot-added continue the search with reserved ranges.
 	 */
-	if (nid != NUMA_NO_NODE)
+	if (nid != NUMA_NO_NODE &&
+		meminfo_to_nid(&numa_reserved_meminfo, start) == NUMA_NO_NODE)
 		return nid;
 
 	return meminfo_to_nid(&numa_reserved_meminfo, start);
-- 
2.33.0



^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] mm: numa_memblks: Identify the accurate NUMA ID of CFMW
  2025-12-30  9:27 [PATCH] mm: numa_memblks: Identify the accurate NUMA ID of CFMW Cui Chao
@ 2025-12-30 15:18 ` Mike Rapoport
  2026-01-05  2:38   ` Cui Chao
  0 siblings, 1 reply; 5+ messages in thread
From: Mike Rapoport @ 2025-12-30 15:18 UTC (permalink / raw)
  To: Cui Chao
  Cc: Andrew Morton, Joanthan Cameron, wangyinfeng, linux-mm, linux-kernel

Hi,

On Tue, Dec 30, 2025 at 05:27:50PM +0800, Cui Chao wrote:
> In some physical memory layout designs, the address space of CFMW
> resides between multiple segments of system memory belonging to
> the same NUMA node. In numa_cleanup_meminfo, these multiple segments
> of system memory are merged into a larger numa_memblk. When
> identifying which NUMA node the CFMW belongs to, it may be incorrectly
> assigned to the NUMA node of the merged system memory. To address this

Can you please provide an example of such memory layout?

> scenario, accurately identifying the correct NUMA node can be achieved
> by checking whether the region belongs to both numa_meminfo and
> numa_reserved_meminfo.
> 
> Signed-off-by: Cui Chao <cuichao1753@phytium.com.cn>
> ---
>  mm/numa_memblks.c | 3 ++-
>  1 file changed, 2 insertions(+), 1 deletion(-)
> 
> diff --git a/mm/numa_memblks.c b/mm/numa_memblks.c
> index 5b009a9cd8b4..1ef037f0e0e0 100644
> --- a/mm/numa_memblks.c
> +++ b/mm/numa_memblks.c
> @@ -573,7 +573,8 @@ int phys_to_target_node(u64 start)
>  	 * Prefer online nodes, but if reserved memory might be
>  	 * hot-added continue the search with reserved ranges.
>  	 */
> -	if (nid != NUMA_NO_NODE)
> +	if (nid != NUMA_NO_NODE &&
> +		meminfo_to_nid(&numa_reserved_meminfo, start) == NUMA_NO_NODE)

I'd suggest assigning the result of meminfo_to_nid(&numa_reserved_meminfo,
start) to a local variable and using that in if and return statements.

>  		return nid;
>  
>  	return meminfo_to_nid(&numa_reserved_meminfo, start);
> -- 
> 2.33.0
> 
> 

-- 
Sincerely yours,
Mike.


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] mm: numa_memblks: Identify the accurate NUMA ID of CFMW
  2025-12-30 15:18 ` Mike Rapoport
@ 2026-01-05  2:38   ` Cui Chao
  2026-01-05  9:34     ` Mike Rapoport
  0 siblings, 1 reply; 5+ messages in thread
From: Cui Chao @ 2026-01-05  2:38 UTC (permalink / raw)
  To: Mike Rapoport
  Cc: Andrew Morton, Joanthan Cameron, wangyinfeng, linux-mm, linux-kernel

Hi,

Thank you for your review.

On 12/30/2025 11:18 PM, Mike Rapoport wrote:
> Hi,
>
> On Tue, Dec 30, 2025 at 05:27:50PM +0800, Cui Chao wrote:
>> In some physical memory layout designs, the address space of CFMW
>> resides between multiple segments of system memory belonging to
>> the same NUMA node. In numa_cleanup_meminfo, these multiple segments
>> of system memory are merged into a larger numa_memblk. When
>> identifying which NUMA node the CFMW belongs to, it may be incorrectly
>> assigned to the NUMA node of the merged system memory. To address this
> Can you please provide an example of such memory layout?


Example memory layout:

Physical address space:
     0x00000000 - 0x1FFFFFFF  System RAM (node0)
     0x20000000 - 0x2FFFFFFF  CXL CFMW (node2)
     0x40000000 - 0x5FFFFFFF  System RAM (node0)
     0x60000000 - 0x7FFFFFFF  System RAM (node1)

After numa_cleanup_meminfo, the two node0 segments are merged into one:
     0x00000000 - 0x5FFFFFFF  System RAM (node0)  // CFMW is inside this 
range
     0x60000000 - 0x7FFFFFFF  System RAM (node1)

So the CFMW (0x20000000-0x2FFFFFFF) will be incorrectly assigned to node0.


>> scenario, accurately identifying the correct NUMA node can be achieved
>> by checking whether the region belongs to both numa_meminfo and
>> numa_reserved_meminfo.
>>
>> Signed-off-by: Cui Chao <cuichao1753@phytium.com.cn>
>> ---
>>   mm/numa_memblks.c | 3 ++-
>>   1 file changed, 2 insertions(+), 1 deletion(-)
>>
>> diff --git a/mm/numa_memblks.c b/mm/numa_memblks.c
>> index 5b009a9cd8b4..1ef037f0e0e0 100644
>> --- a/mm/numa_memblks.c
>> +++ b/mm/numa_memblks.c
>> @@ -573,7 +573,8 @@ int phys_to_target_node(u64 start)
>>   	 * Prefer online nodes, but if reserved memory might be
>>   	 * hot-added continue the search with reserved ranges.
>>   	 */
>> -	if (nid != NUMA_NO_NODE)
>> +	if (nid != NUMA_NO_NODE &&
>> +		meminfo_to_nid(&numa_reserved_meminfo, start) == NUMA_NO_NODE)
> I'd suggest assigning the result of meminfo_to_nid(&numa_reserved_meminfo,
> start) to a local variable and using that in if and return statements.


I will use a local variable named reserved_nid.


>>   		return nid;
>>   
>>   	return meminfo_to_nid(&numa_reserved_meminfo, start);
>> -- 
>> 2.33.0
>>
>>
-- 
Best regards,
Cui Chao.



^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] mm: numa_memblks: Identify the accurate NUMA ID of CFMW
  2026-01-05  2:38   ` Cui Chao
@ 2026-01-05  9:34     ` Mike Rapoport
  2026-01-05  9:59       ` Jonathan Cameron
  0 siblings, 1 reply; 5+ messages in thread
From: Mike Rapoport @ 2026-01-05  9:34 UTC (permalink / raw)
  To: Cui Chao
  Cc: Andrew Morton, Joanthan Cameron, wangyinfeng, linux-mm, linux-kernel

On Mon, Jan 05, 2026 at 10:38:30AM +0800, Cui Chao wrote:
> Hi,
> 
> Thank you for your review.
> 
> On 12/30/2025 11:18 PM, Mike Rapoport wrote:
> > Hi,
> > 
> > On Tue, Dec 30, 2025 at 05:27:50PM +0800, Cui Chao wrote:
> > > In some physical memory layout designs, the address space of CFMW
> > > resides between multiple segments of system memory belonging to
> > > the same NUMA node. In numa_cleanup_meminfo, these multiple segments
> > > of system memory are merged into a larger numa_memblk. When
> > > identifying which NUMA node the CFMW belongs to, it may be incorrectly
> > > assigned to the NUMA node of the merged system memory. To address this
> > Can you please provide an example of such memory layout?
> 
> Example memory layout:
> 
> Physical address space:
>     0x00000000 - 0x1FFFFFFF  System RAM (node0)
>     0x20000000 - 0x2FFFFFFF  CXL CFMW (node2)
>     0x40000000 - 0x5FFFFFFF  System RAM (node0)
>     0x60000000 - 0x7FFFFFFF  System RAM (node1)
> 
> After numa_cleanup_meminfo, the two node0 segments are merged into one:
>     0x00000000 - 0x5FFFFFFF  System RAM (node0)  // CFMW is inside this
> range
>     0x60000000 - 0x7FFFFFFF  System RAM (node1)
> 
> So the CFMW (0x20000000-0x2FFFFFFF) will be incorrectly assigned to node0.

Can you please add this example to the changelog? 
 
> > > scenario, accurately identifying the correct NUMA node can be achieved
> > > by checking whether the region belongs to both numa_meminfo and
> > > numa_reserved_meminfo.
> > > 
> > > Signed-off-by: Cui Chao <cuichao1753@phytium.com.cn>

-- 
Sincerely yours,
Mike.


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] mm: numa_memblks: Identify the accurate NUMA ID of CFMW
  2026-01-05  9:34     ` Mike Rapoport
@ 2026-01-05  9:59       ` Jonathan Cameron
  0 siblings, 0 replies; 5+ messages in thread
From: Jonathan Cameron @ 2026-01-05  9:59 UTC (permalink / raw)
  To: Mike Rapoport
  Cc: Cui Chao, Andrew Morton, wangyinfeng, linux-mm, linux-kernel

On Mon, 5 Jan 2026 11:34:55 +0200
Mike Rapoport <rppt@kernel.org> wrote:

> On Mon, Jan 05, 2026 at 10:38:30AM +0800, Cui Chao wrote:
> > Hi,
> > 
> > Thank you for your review.
> > 
> > On 12/30/2025 11:18 PM, Mike Rapoport wrote:  
> > > Hi,
> > > 
> > > On Tue, Dec 30, 2025 at 05:27:50PM +0800, Cui Chao wrote:  
> > > > In some physical memory layout designs, the address space of CFMW
> > > > resides between multiple segments of system memory belonging to
> > > > the same NUMA node. In numa_cleanup_meminfo, these multiple segments
> > > > of system memory are merged into a larger numa_memblk. When
> > > > identifying which NUMA node the CFMW belongs to, it may be incorrectly
> > > > assigned to the NUMA node of the merged system memory. To address this  
> > > Can you please provide an example of such memory layout?  
> > 
> > Example memory layout:
> > 
> > Physical address space:
> >     0x00000000 - 0x1FFFFFFF  System RAM (node0)
> >     0x20000000 - 0x2FFFFFFF  CXL CFMW (node2)
> >     0x40000000 - 0x5FFFFFFF  System RAM (node0)
> >     0x60000000 - 0x7FFFFFFF  System RAM (node1)
> > 
> > After numa_cleanup_meminfo, the two node0 segments are merged into one:
> >     0x00000000 - 0x5FFFFFFF  System RAM (node0)  // CFMW is inside this
> > range
> >     0x60000000 - 0x7FFFFFFF  System RAM (node1)
> > 
> > So the CFMW (0x20000000-0x2FFFFFFF) will be incorrectly assigned to node0.  
> 
> Can you please add this example to the changelog? #
Also, please +CC linux-cxl@vger.kernel.org given this is all about how
we handle the CXL fixed memory windows.

>  
> > > > scenario, accurately identifying the correct NUMA node can be achieved
> > > > by checking whether the region belongs to both numa_meminfo and
> > > > numa_reserved_meminfo.
> > > > 
> > > > Signed-off-by: Cui Chao <cuichao1753@phytium.com.cn>  
> 



^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2026-01-05  9:59 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-12-30  9:27 [PATCH] mm: numa_memblks: Identify the accurate NUMA ID of CFMW Cui Chao
2025-12-30 15:18 ` Mike Rapoport
2026-01-05  2:38   ` Cui Chao
2026-01-05  9:34     ` Mike Rapoport
2026-01-05  9:59       ` Jonathan Cameron

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox