Linux CXL
 help / color / mirror / Atom feed
* [PATCH] cxl_test: Limit location for fake CFMWS to mappable range
@ 2025-05-27 15:34 Jonathan Cameron
  2025-05-27 19:31 ` Alison Schofield
  2025-06-09 17:25 ` Dave Jiang
  0 siblings, 2 replies; 6+ messages in thread
From: Jonathan Cameron @ 2025-05-27 15:34 UTC (permalink / raw)
  To: linux-cxl
  Cc: Itaru Kitayama, Dan Williams, Marc Herbert, Alison Schofield,
	Dave Jiang, linuxarm

Some architectures (e.g. arm64) only support memory hotplug operations on
a restricted set of physical addresses. This applies even when we are
faking some CXL fixed memory windows for the purposes of cxl_test.
That range can be queried with mhp_get_pluggable_range(true). Use the
minimum of that the top of that range and iomem_resource.end to establish
the 64GiB region used by cxl_test.

From thread #2 which was related to the issue in #1.

Link: https://lore.kernel.org/linux-cxl/20250522145622.00002633@huawei.com/ #2
Reported-by: Itaru Kitayama <itaru.kitayama@linux.dev>
Closes: https://github.com/pmem/ndctl/issues/278 #1
Reviewed-by: Dan Williams <dan.j.williams@intel.com>
Tested-by: Itaru Kitayama <itaru.kitayama@fujitsu.com <mailto:itaru.kitayama@fujitsu.com>
Tested-by: Marc Herbert <marc.herbert@linux.intel.com>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>

---
I haven't given this a fixes tag because it never worked on arm64.
So it isn't a regression fix, and I'm not sure we want to back port this
which a fixes tag might well trigger.  If people want one shout and I'll
try and figure out what is appropriate.
---
 tools/testing/cxl/test/cxl.c | 7 ++++++-
 1 file changed, 6 insertions(+), 1 deletion(-)

diff --git a/tools/testing/cxl/test/cxl.c b/tools/testing/cxl/test/cxl.c
index 8a5815ca870d..6a25cca5636f 100644
--- a/tools/testing/cxl/test/cxl.c
+++ b/tools/testing/cxl/test/cxl.c
@@ -2,6 +2,7 @@
 // Copyright(c) 2021 Intel Corporation. All rights reserved.
 
 #include <linux/platform_device.h>
+#include <linux/memory_hotplug.h>
 #include <linux/genalloc.h>
 #include <linux/module.h>
 #include <linux/mutex.h>
@@ -1328,6 +1329,7 @@ static int cxl_mem_init(void)
 static __init int cxl_test_init(void)
 {
 	int rc, i;
+	struct range mappable;
 
 	cxl_acpi_test();
 	cxl_core_test();
@@ -1342,8 +1344,11 @@ static __init int cxl_test_init(void)
 		rc = -ENOMEM;
 		goto err_gen_pool_create;
 	}
+	mappable = mhp_get_pluggable_range(true);
 
-	rc = gen_pool_add(cxl_mock_pool, iomem_resource.end + 1 - SZ_64G,
+	rc = gen_pool_add(cxl_mock_pool,
+			  min(iomem_resource.end + 1 - SZ_64G,
+			      mappable.end + 1 - SZ_64G),
 			  SZ_64G, NUMA_NO_NODE);
 	if (rc)
 		goto err_gen_pool_add;
-- 
2.43.0


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

* Re: [PATCH] cxl_test: Limit location for fake CFMWS to mappable range
  2025-05-27 15:34 [PATCH] cxl_test: Limit location for fake CFMWS to mappable range Jonathan Cameron
@ 2025-05-27 19:31 ` Alison Schofield
  2025-06-09 17:25 ` Dave Jiang
  1 sibling, 0 replies; 6+ messages in thread
From: Alison Schofield @ 2025-05-27 19:31 UTC (permalink / raw)
  To: Jonathan Cameron
  Cc: linux-cxl, Itaru Kitayama, Dan Williams, Marc Herbert, Dave Jiang,
	linuxarm

On Tue, May 27, 2025 at 04:34:51PM +0100, Jonathan Cameron wrote:
> Some architectures (e.g. arm64) only support memory hotplug operations on
> a restricted set of physical addresses. This applies even when we are
> faking some CXL fixed memory windows for the purposes of cxl_test.
> That range can be queried with mhp_get_pluggable_range(true). Use the
> minimum of that the top of that range and iomem_resource.end to establish
> the 64GiB region used by cxl_test.
> 
> From thread #2 which was related to the issue in #1.
> 
> Link: https://lore.kernel.org/linux-cxl/20250522145622.00002633@huawei.com/ #2
> Reported-by: Itaru Kitayama <itaru.kitayama@linux.dev>
> Closes: https://github.com/pmem/ndctl/issues/278 #1
> Reviewed-by: Dan Williams <dan.j.williams@intel.com>
> Tested-by: Itaru Kitayama <itaru.kitayama@fujitsu.com <mailto:itaru.kitayama@fujitsu.com>
> Tested-by: Marc Herbert <marc.herbert@linux.intel.com>
> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
> 
> ---
> I haven't given this a fixes tag because it never worked on arm64.
> So it isn't a regression fix, and I'm not sure we want to back port this
> which a fixes tag might well trigger.  If people want one shout and I'll
> try and figure out what is appropriate.
> ---
>  tools/testing/cxl/test/cxl.c | 7 ++++++-
>  1 file changed, 6 insertions(+), 1 deletion(-)
> 
> diff --git a/tools/testing/cxl/test/cxl.c b/tools/testing/cxl/test/cxl.c
> index 8a5815ca870d..6a25cca5636f 100644
> --- a/tools/testing/cxl/test/cxl.c
> +++ b/tools/testing/cxl/test/cxl.c
> @@ -2,6 +2,7 @@
>  // Copyright(c) 2021 Intel Corporation. All rights reserved.
>  
>  #include <linux/platform_device.h>
> +#include <linux/memory_hotplug.h>
>  #include <linux/genalloc.h>
>  #include <linux/module.h>
>  #include <linux/mutex.h>
> @@ -1328,6 +1329,7 @@ static int cxl_mem_init(void)
>  static __init int cxl_test_init(void)
>  {
>  	int rc, i;
> +	struct range mappable;
>  
>  	cxl_acpi_test();
>  	cxl_core_test();
> @@ -1342,8 +1344,11 @@ static __init int cxl_test_init(void)
>  		rc = -ENOMEM;
>  		goto err_gen_pool_create;
>  	}
> +	mappable = mhp_get_pluggable_range(true);

mhp_get_pluaggable_range() is only defined w CONFIG_MEMORY_HOTPLUG

This to tools/testing/cxl/config_check.c works for me:
+       BUILD_BUG_ON(!IS_ENABLED(CONFIG_MEMORY_HOTPLUG));


>  
> -	rc = gen_pool_add(cxl_mock_pool, iomem_resource.end + 1 - SZ_64G,
> +	rc = gen_pool_add(cxl_mock_pool,
> +			  min(iomem_resource.end + 1 - SZ_64G,
> +			      mappable.end + 1 - SZ_64G),
>  			  SZ_64G, NUMA_NO_NODE);
>  	if (rc)
>  		goto err_gen_pool_add;
> -- 
> 2.43.0
> 

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

* Re: [PATCH] cxl_test: Limit location for fake CFMWS to mappable range
  2025-05-27 15:34 [PATCH] cxl_test: Limit location for fake CFMWS to mappable range Jonathan Cameron
  2025-05-27 19:31 ` Alison Schofield
@ 2025-06-09 17:25 ` Dave Jiang
  2025-06-10  9:17   ` Jonathan Cameron
  1 sibling, 1 reply; 6+ messages in thread
From: Dave Jiang @ 2025-06-09 17:25 UTC (permalink / raw)
  To: Jonathan Cameron, linux-cxl
  Cc: Itaru Kitayama, Dan Williams, Marc Herbert, Alison Schofield,
	linuxarm



On 5/27/25 8:34 AM, Jonathan Cameron wrote:
> Some architectures (e.g. arm64) only support memory hotplug operations on
> a restricted set of physical addresses. This applies even when we are
> faking some CXL fixed memory windows for the purposes of cxl_test.
> That range can be queried with mhp_get_pluggable_range(true). Use the
> minimum of that the top of that range and iomem_resource.end to establish
> the 64GiB region used by cxl_test.
> 
> From thread #2 which was related to the issue in #1.
> 
> Link: https://lore.kernel.org/linux-cxl/20250522145622.00002633@huawei.com/ #2
> Reported-by: Itaru Kitayama <itaru.kitayama@linux.dev>
> Closes: https://github.com/pmem/ndctl/issues/278 #1
> Reviewed-by: Dan Williams <dan.j.williams@intel.com>
> Tested-by: Itaru Kitayama <itaru.kitayama@fujitsu.com <mailto:itaru.kitayama@fujitsu.com>
> Tested-by: Marc Herbert <marc.herbert@linux.intel.com>
> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>

Applied to cxl/next

Added the config check from Alison

> 
> ---
> I haven't given this a fixes tag because it never worked on arm64.
> So it isn't a regression fix, and I'm not sure we want to back port this
> which a fixes tag might well trigger.  If people want one shout and I'll
> try and figure out what is appropriate.
> ---
>  tools/testing/cxl/test/cxl.c | 7 ++++++-
>  1 file changed, 6 insertions(+), 1 deletion(-)
> 
> diff --git a/tools/testing/cxl/test/cxl.c b/tools/testing/cxl/test/cxl.c
> index 8a5815ca870d..6a25cca5636f 100644
> --- a/tools/testing/cxl/test/cxl.c
> +++ b/tools/testing/cxl/test/cxl.c
> @@ -2,6 +2,7 @@
>  // Copyright(c) 2021 Intel Corporation. All rights reserved.
>  
>  #include <linux/platform_device.h>
> +#include <linux/memory_hotplug.h>
>  #include <linux/genalloc.h>
>  #include <linux/module.h>
>  #include <linux/mutex.h>
> @@ -1328,6 +1329,7 @@ static int cxl_mem_init(void)
>  static __init int cxl_test_init(void)
>  {
>  	int rc, i;
> +	struct range mappable;
>  
>  	cxl_acpi_test();
>  	cxl_core_test();
> @@ -1342,8 +1344,11 @@ static __init int cxl_test_init(void)
>  		rc = -ENOMEM;
>  		goto err_gen_pool_create;
>  	}
> +	mappable = mhp_get_pluggable_range(true);
>  
> -	rc = gen_pool_add(cxl_mock_pool, iomem_resource.end + 1 - SZ_64G,
> +	rc = gen_pool_add(cxl_mock_pool,
> +			  min(iomem_resource.end + 1 - SZ_64G,
> +			      mappable.end + 1 - SZ_64G),
>  			  SZ_64G, NUMA_NO_NODE);
>  	if (rc)
>  		goto err_gen_pool_add;


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

* Re: [PATCH] cxl_test: Limit location for fake CFMWS to mappable range
@ 2025-06-10  0:02 Itaru Kitayama
  2025-06-10  0:07 ` Dave Jiang
  0 siblings, 1 reply; 6+ messages in thread
From: Itaru Kitayama @ 2025-06-10  0:02 UTC (permalink / raw)
  To: Dave Jiang
  Cc: Jonathan Cameron, linux-cxl, Dan Williams, Marc Herbert,
	Alison Schofield, linuxarm



> On Jun 10, 2025, at 2:25, Dave Jiang <dave.jiang@intel.com> wrote:
> 
> 
> 
>> On 5/27/25 8:34 AM, Jonathan Cameron wrote:
>> Some architectures (e.g. arm64) only support memory hotplug operations on
>> a restricted set of physical addresses. This applies even when we are
>> faking some CXL fixed memory windows for the purposes of cxl_test.
>> That range can be queried with mhp_get_pluggable_range(true). Use the
>> minimum of that the top of that range and iomem_resource.end to establish
>> the 64GiB region used by cxl_test.
>> 
>> From thread #2 which was related to the issue in #1.
>> 
>> Link: https://lore.kernel.org/linux-cxl/20250522145622.00002633@huawei.com/ #2
>> Reported-by: Itaru Kitayama <itaru.kitayama@linux.dev>
>> Closes: https://github.com/pmem/ndctl/issues/278 #1
>> Reviewed-by: Dan Williams <dan.j.williams@intel.com>
>> Tested-by: Itaru Kitayama <itaru.kitayama@fujitsu.com <mailto:itaru.kitayama@fujitsu.com>
>> Tested-by: Marc Herbert <marc.herbert@linux.intel.com>
>> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
> 
> Applied to cxl/next
> 
> Added the config check from Alison

Can this go into the 6.16 release cycle -rc2 or -rc3?

Itaru.

> 
>> 
>> ---
>> I haven't given this a fixes tag because it never worked on arm64.
>> So it isn't a regression fix, and I'm not sure we want to back port this
>> which a fixes tag might well trigger.  If people want one shout and I'll
>> try and figure out what is appropriate.
>> ---
>> tools/testing/cxl/test/cxl.c | 7 ++++++-
>> 1 file changed, 6 insertions(+), 1 deletion(-)
>> 
>> diff --git a/tools/testing/cxl/test/cxl.c b/tools/testing/cxl/test/cxl.c
>> index 8a5815ca870d..6a25cca5636f 100644
>> --- a/tools/testing/cxl/test/cxl.c
>> +++ b/tools/testing/cxl/test/cxl.c
>> @@ -2,6 +2,7 @@
>> // Copyright(c) 2021 Intel Corporation. All rights reserved.
>> 
>> #include <linux/platform_device.h>
>> +#include <linux/memory_hotplug.h>
>> #include <linux/genalloc.h>
>> #include <linux/module.h>
>> #include <linux/mutex.h>
>> @@ -1328,6 +1329,7 @@ static int cxl_mem_init(void)
>> static __init int cxl_test_init(void)
>> {
>>    int rc, i;
>> +    struct range mappable;
>> 
>>    cxl_acpi_test();
>>    cxl_core_test();
>> @@ -1342,8 +1344,11 @@ static __init int cxl_test_init(void)
>>        rc = -ENOMEM;
>>        goto err_gen_pool_create;
>>    }
>> +    mappable = mhp_get_pluggable_range(true);
>> 
>> -    rc = gen_pool_add(cxl_mock_pool, iomem_resource.end + 1 - SZ_64G,
>> +    rc = gen_pool_add(cxl_mock_pool,
>> +              min(iomem_resource.end + 1 - SZ_64G,
>> +                  mappable.end + 1 - SZ_64G),
>>              SZ_64G, NUMA_NO_NODE);
>>    if (rc)
>>        goto err_gen_pool_add;
> 

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

* Re: [PATCH] cxl_test: Limit location for fake CFMWS to mappable range
  2025-06-10  0:02 Itaru Kitayama
@ 2025-06-10  0:07 ` Dave Jiang
  0 siblings, 0 replies; 6+ messages in thread
From: Dave Jiang @ 2025-06-10  0:07 UTC (permalink / raw)
  To: Itaru Kitayama
  Cc: Jonathan Cameron, linux-cxl, Dan Williams, Marc Herbert,
	Alison Schofield, linuxarm



On 6/9/25 5:02 PM, Itaru Kitayama wrote:
> 
> 
>> On Jun 10, 2025, at 2:25, Dave Jiang <dave.jiang@intel.com> wrote:
>>
>> 
>>
>>> On 5/27/25 8:34 AM, Jonathan Cameron wrote:
>>> Some architectures (e.g. arm64) only support memory hotplug operations on
>>> a restricted set of physical addresses. This applies even when we are
>>> faking some CXL fixed memory windows for the purposes of cxl_test.
>>> That range can be queried with mhp_get_pluggable_range(true). Use the
>>> minimum of that the top of that range and iomem_resource.end to establish
>>> the 64GiB region used by cxl_test.
>>>
>>> From thread #2 which was related to the issue in #1.
>>>
>>> Link: https://lore.kernel.org/linux-cxl/20250522145622.00002633@huawei.com/ #2
>>> Reported-by: Itaru Kitayama <itaru.kitayama@linux.dev>
>>> Closes: https://github.com/pmem/ndctl/issues/278 #1
>>> Reviewed-by: Dan Williams <dan.j.williams@intel.com>
>>> Tested-by: Itaru Kitayama <itaru.kitayama@fujitsu.com <mailto:itaru.kitayama@fujitsu.com>
>>> Tested-by: Marc Herbert <marc.herbert@linux.intel.com>
>>> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
>>
>> Applied to cxl/next
>>
>> Added the config check from Alison
> 
> Can this go into the 6.16 release cycle -rc2 or -rc3?

Given that it doesn't break the actual kernel, it's going in 6.17.

> 
> Itaru.
> 
>>
>>>
>>> ---
>>> I haven't given this a fixes tag because it never worked on arm64.
>>> So it isn't a regression fix, and I'm not sure we want to back port this
>>> which a fixes tag might well trigger.  If people want one shout and I'll
>>> try and figure out what is appropriate.
>>> ---
>>> tools/testing/cxl/test/cxl.c | 7 ++++++-
>>> 1 file changed, 6 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/tools/testing/cxl/test/cxl.c b/tools/testing/cxl/test/cxl.c
>>> index 8a5815ca870d..6a25cca5636f 100644
>>> --- a/tools/testing/cxl/test/cxl.c
>>> +++ b/tools/testing/cxl/test/cxl.c
>>> @@ -2,6 +2,7 @@
>>> // Copyright(c) 2021 Intel Corporation. All rights reserved.
>>>
>>> #include <linux/platform_device.h>
>>> +#include <linux/memory_hotplug.h>
>>> #include <linux/genalloc.h>
>>> #include <linux/module.h>
>>> #include <linux/mutex.h>
>>> @@ -1328,6 +1329,7 @@ static int cxl_mem_init(void)
>>> static __init int cxl_test_init(void)
>>> {
>>>    int rc, i;
>>> +    struct range mappable;
>>>
>>>    cxl_acpi_test();
>>>    cxl_core_test();
>>> @@ -1342,8 +1344,11 @@ static __init int cxl_test_init(void)
>>>        rc = -ENOMEM;
>>>        goto err_gen_pool_create;
>>>    }
>>> +    mappable = mhp_get_pluggable_range(true);
>>>
>>> -    rc = gen_pool_add(cxl_mock_pool, iomem_resource.end + 1 - SZ_64G,
>>> +    rc = gen_pool_add(cxl_mock_pool,
>>> +              min(iomem_resource.end + 1 - SZ_64G,
>>> +                  mappable.end + 1 - SZ_64G),
>>>              SZ_64G, NUMA_NO_NODE);
>>>    if (rc)
>>>        goto err_gen_pool_add;
>>
> 


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

* Re: [PATCH] cxl_test: Limit location for fake CFMWS to mappable range
  2025-06-09 17:25 ` Dave Jiang
@ 2025-06-10  9:17   ` Jonathan Cameron
  0 siblings, 0 replies; 6+ messages in thread
From: Jonathan Cameron @ 2025-06-10  9:17 UTC (permalink / raw)
  To: Dave Jiang
  Cc: linux-cxl, Itaru Kitayama, Dan Williams, Marc Herbert,
	Alison Schofield, linuxarm

On Mon, 9 Jun 2025 10:25:41 -0700
Dave Jiang <dave.jiang@intel.com> wrote:

> On 5/27/25 8:34 AM, Jonathan Cameron wrote:
> > Some architectures (e.g. arm64) only support memory hotplug operations on
> > a restricted set of physical addresses. This applies even when we are
> > faking some CXL fixed memory windows for the purposes of cxl_test.
> > That range can be queried with mhp_get_pluggable_range(true). Use the
> > minimum of that the top of that range and iomem_resource.end to establish
> > the 64GiB region used by cxl_test.
> > 
> > From thread #2 which was related to the issue in #1.
> > 
> > Link: https://lore.kernel.org/linux-cxl/20250522145622.00002633@huawei.com/ #2
> > Reported-by: Itaru Kitayama <itaru.kitayama@linux.dev>
> > Closes: https://github.com/pmem/ndctl/issues/278 #1
> > Reviewed-by: Dan Williams <dan.j.williams@intel.com>
> > Tested-by: Itaru Kitayama <itaru.kitayama@fujitsu.com <mailto:itaru.kitayama@fujitsu.com>
> > Tested-by: Marc Herbert <marc.herbert@linux.intel.com>
> > Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>  
> 
> Applied to cxl/next
> 
> Added the config check from Alison
Thanks. Was about to send v2 but this is quicker ;)


> 
> > 
> > ---
> > I haven't given this a fixes tag because it never worked on arm64.
> > So it isn't a regression fix, and I'm not sure we want to back port this
> > which a fixes tag might well trigger.  If people want one shout and I'll
> > try and figure out what is appropriate.
> > ---
> >  tools/testing/cxl/test/cxl.c | 7 ++++++-
> >  1 file changed, 6 insertions(+), 1 deletion(-)
> > 
> > diff --git a/tools/testing/cxl/test/cxl.c b/tools/testing/cxl/test/cxl.c
> > index 8a5815ca870d..6a25cca5636f 100644
> > --- a/tools/testing/cxl/test/cxl.c
> > +++ b/tools/testing/cxl/test/cxl.c
> > @@ -2,6 +2,7 @@
> >  // Copyright(c) 2021 Intel Corporation. All rights reserved.
> >  
> >  #include <linux/platform_device.h>
> > +#include <linux/memory_hotplug.h>
> >  #include <linux/genalloc.h>
> >  #include <linux/module.h>
> >  #include <linux/mutex.h>
> > @@ -1328,6 +1329,7 @@ static int cxl_mem_init(void)
> >  static __init int cxl_test_init(void)
> >  {
> >  	int rc, i;
> > +	struct range mappable;
> >  
> >  	cxl_acpi_test();
> >  	cxl_core_test();
> > @@ -1342,8 +1344,11 @@ static __init int cxl_test_init(void)
> >  		rc = -ENOMEM;
> >  		goto err_gen_pool_create;
> >  	}
> > +	mappable = mhp_get_pluggable_range(true);
> >  
> > -	rc = gen_pool_add(cxl_mock_pool, iomem_resource.end + 1 - SZ_64G,
> > +	rc = gen_pool_add(cxl_mock_pool,
> > +			  min(iomem_resource.end + 1 - SZ_64G,
> > +			      mappable.end + 1 - SZ_64G),
> >  			  SZ_64G, NUMA_NO_NODE);
> >  	if (rc)
> >  		goto err_gen_pool_add;  
> 
> 


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

end of thread, other threads:[~2025-06-10  9:17 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-05-27 15:34 [PATCH] cxl_test: Limit location for fake CFMWS to mappable range Jonathan Cameron
2025-05-27 19:31 ` Alison Schofield
2025-06-09 17:25 ` Dave Jiang
2025-06-10  9:17   ` Jonathan Cameron
  -- strict thread matches above, loose matches on Subject: below --
2025-06-10  0:02 Itaru Kitayama
2025-06-10  0:07 ` Dave Jiang

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