* [PATCH] drm/ttm: Support 52-bit PAs in ttm_place
@ 2026-05-12 22:31 Felix Kuehling
2026-05-13 8:08 ` Christian König
` (2 more replies)
0 siblings, 3 replies; 6+ messages in thread
From: Felix Kuehling @ 2026-05-12 22:31 UTC (permalink / raw)
To: amd-gfx, dri-devel; +Cc: christian.koenig
fpfn and lpfn in struct ttm_place are 32-bit page numbers. With 4KB page
size this can support up to 44-bit physical addressing. Grow these to
unsigned long to support larger physical addresses.
Signed-off-by: Felix Kuehling <felix.kuehling@amd.com>
---
include/drm/ttm/ttm_placement.h | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/include/drm/ttm/ttm_placement.h b/include/drm/ttm/ttm_placement.h
index b510a4812609..3e88869c0f58 100644
--- a/include/drm/ttm/ttm_placement.h
+++ b/include/drm/ttm/ttm_placement.h
@@ -81,8 +81,8 @@
* Structure indicating a possible place to put an object.
*/
struct ttm_place {
- unsigned fpfn;
- unsigned lpfn;
+ unsigned long fpfn;
+ unsigned long lpfn;
uint32_t mem_type;
uint32_t flags;
};
--
2.43.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH] drm/ttm: Support 52-bit PAs in ttm_place
2026-05-12 22:31 [PATCH] drm/ttm: Support 52-bit PAs in ttm_place Felix Kuehling
@ 2026-05-13 8:08 ` Christian König
2026-05-13 14:15 ` Kuehling, Felix
2026-05-16 2:38 ` Claude review: " Claude Code Review Bot
2026-05-16 2:39 ` Claude Code Review Bot
2 siblings, 1 reply; 6+ messages in thread
From: Christian König @ 2026-05-13 8:08 UTC (permalink / raw)
To: Felix Kuehling, amd-gfx, dri-devel
On 5/13/26 00:31, Felix Kuehling wrote:
> fpfn and lpfn in struct ttm_place are 32-bit page numbers. With 4KB page
> size this can support up to 44-bit physical addressing. Grow these to
> unsigned long to support larger physical addresses.
>
> Signed-off-by: Felix Kuehling <felix.kuehling@amd.com>
> ---
> include/drm/ttm/ttm_placement.h | 4 ++--
> 1 file changed, 2 insertions(+), 2 deletions(-)
>
> diff --git a/include/drm/ttm/ttm_placement.h b/include/drm/ttm/ttm_placement.h
> index b510a4812609..3e88869c0f58 100644
> --- a/include/drm/ttm/ttm_placement.h
> +++ b/include/drm/ttm/ttm_placement.h
> @@ -81,8 +81,8 @@
> * Structure indicating a possible place to put an object.
> */
> struct ttm_place {
> - unsigned fpfn;
> - unsigned lpfn;
> + unsigned long fpfn;
> + unsigned long lpfn;
That should be uint64_t instead, long is CPU architecture dependent and we clearly don't want that in TTM.
But apart from that looks reasonable to me.
Regards,
Christian.
> uint32_t mem_type;
> uint32_t flags;
> };
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] drm/ttm: Support 52-bit PAs in ttm_place
2026-05-13 8:08 ` Christian König
@ 2026-05-13 14:15 ` Kuehling, Felix
2026-05-13 15:42 ` Christian König
0 siblings, 1 reply; 6+ messages in thread
From: Kuehling, Felix @ 2026-05-13 14:15 UTC (permalink / raw)
To: Christian König, amd-gfx, dri-devel
On 2026-05-13 03:08, Christian König wrote:
>
> On 5/13/26 00:31, Felix Kuehling wrote:
>> fpfn and lpfn in struct ttm_place are 32-bit page numbers. With 4KB page
>> size this can support up to 44-bit physical addressing. Grow these to
>> unsigned long to support larger physical addresses.
>>
>> Signed-off-by: Felix Kuehling <felix.kuehling@amd.com>
>> ---
>> include/drm/ttm/ttm_placement.h | 4 ++--
>> 1 file changed, 2 insertions(+), 2 deletions(-)
>>
>> diff --git a/include/drm/ttm/ttm_placement.h b/include/drm/ttm/ttm_placement.h
>> index b510a4812609..3e88869c0f58 100644
>> --- a/include/drm/ttm/ttm_placement.h
>> +++ b/include/drm/ttm/ttm_placement.h
>> @@ -81,8 +81,8 @@
>> * Structure indicating a possible place to put an object.
>> */
>> struct ttm_place {
>> - unsigned fpfn;
>> - unsigned lpfn;
>> + unsigned long fpfn;
>> + unsigned long lpfn;
> That should be uint64_t instead, long is CPU architecture dependent and we clearly don't want that in TTM.
>
> But apart from that looks reasonable to me.
Thanks. I sent out v2. What's the best branch for getting this change
upstream? We'll need it on our NPI branch in the interim.
Regards,
Felix
>
> Regards,
> Christian.
>
>> uint32_t mem_type;
>> uint32_t flags;
>> };
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH] drm/ttm: Support 52-bit PAs in ttm_place
2026-05-13 14:15 ` Kuehling, Felix
@ 2026-05-13 15:42 ` Christian König
0 siblings, 0 replies; 6+ messages in thread
From: Christian König @ 2026-05-13 15:42 UTC (permalink / raw)
To: Kuehling, Felix, amd-gfx, dri-devel
On 5/13/26 16:15, Kuehling, Felix wrote:
> On 2026-05-13 03:08, Christian König wrote:
>>
>> On 5/13/26 00:31, Felix Kuehling wrote:
>>> fpfn and lpfn in struct ttm_place are 32-bit page numbers. With 4KB page
>>> size this can support up to 44-bit physical addressing. Grow these to
>>> unsigned long to support larger physical addresses.
>>>
>>> Signed-off-by: Felix Kuehling <felix.kuehling@amd.com>
>>> ---
>>> include/drm/ttm/ttm_placement.h | 4 ++--
>>> 1 file changed, 2 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/include/drm/ttm/ttm_placement.h b/include/drm/ttm/ttm_placement.h
>>> index b510a4812609..3e88869c0f58 100644
>>> --- a/include/drm/ttm/ttm_placement.h
>>> +++ b/include/drm/ttm/ttm_placement.h
>>> @@ -81,8 +81,8 @@
>>> * Structure indicating a possible place to put an object.
>>> */
>>> struct ttm_place {
>>> - unsigned fpfn;
>>> - unsigned lpfn;
>>> + unsigned long fpfn;
>>> + unsigned long lpfn;
>> That should be uint64_t instead, long is CPU architecture dependent and we clearly don't want that in TTM.
>>
>> But apart from that looks reasonable to me.
>
> Thanks. I sent out v2. What's the best branch for getting this change upstream? We'll need it on our NPI branch in the interim.
Arun will push it to drm-misc-next, if you also need it in amd-staging-drm-next you need to sync up with Alex. But that shouldn't be much of a problem.
Regards,
Christian
>
> Regards,
> Felix
>
>
>>
>> Regards,
>> Christian.
>>
>>> uint32_t mem_type;
>>> uint32_t flags;
>>> };
^ permalink raw reply [flat|nested] 6+ messages in thread
* Claude review: drm/ttm: Support 52-bit PAs in ttm_place
2026-05-12 22:31 [PATCH] drm/ttm: Support 52-bit PAs in ttm_place Felix Kuehling
2026-05-13 8:08 ` Christian König
@ 2026-05-16 2:38 ` Claude Code Review Bot
2026-05-16 2:39 ` Claude Code Review Bot
2 siblings, 0 replies; 6+ messages in thread
From: Claude Code Review Bot @ 2026-05-16 2:38 UTC (permalink / raw)
To: dri-devel-reviews
Overall Series Review
Subject: drm/ttm: Support 52-bit PAs in ttm_place
Author: Felix Kuehling <felix.kuehling@amd.com>
Patches: 4
Reviewed: 2026-05-16T12:38:59.764368
---
This is a single patch that widens `fpfn` and `lpfn` in `struct ttm_place` from `unsigned` (32-bit) to `unsigned long` to support physical addresses beyond 44 bits (32-bit page numbers × 4KB pages). The motivation is sound — 32-bit page frame numbers limit addressing to 16 TiB, which is increasingly insufficient.
However, **this patch is already superseded by work in drm-next**. The current drm-next tree already has these fields as `uint64_t`:
```c
struct ttm_place {
uint64_t fpfn;
uint64_t lpfn;
uint32_t mem_type;
uint32_t flags;
};
```
The `uint64_t` approach in drm-next is **strictly better** than the `unsigned long` proposed here, because `unsigned long` is only 32-bit on 32-bit platforms, providing no improvement there, while `uint64_t` is unconditionally 64-bit.
**Recommendation: NAK — this change has already landed in drm-next with a superior type choice (`uint64_t` vs `unsigned long`).**
---
---
Generated by Claude Code Patch Reviewer
^ permalink raw reply [flat|nested] 6+ messages in thread
* Claude review: drm/ttm: Support 52-bit PAs in ttm_place
2026-05-12 22:31 [PATCH] drm/ttm: Support 52-bit PAs in ttm_place Felix Kuehling
2026-05-13 8:08 ` Christian König
2026-05-16 2:38 ` Claude review: " Claude Code Review Bot
@ 2026-05-16 2:39 ` Claude Code Review Bot
2 siblings, 0 replies; 6+ messages in thread
From: Claude Code Review Bot @ 2026-05-16 2:39 UTC (permalink / raw)
To: dri-devel-reviews
Patch Review
**Already superseded in drm-next.** The fields have been changed to `uint64_t`, which is the correct fix.
**Type choice concern:** Even if this weren't superseded, `unsigned long` would be the wrong type here. On 32-bit kernels, `unsigned long` is 32 bits — identical to `unsigned` — so the patch would silently provide no benefit on those platforms. The `uint64_t` already in drm-next avoids this problem.
```c
- unsigned fpfn;
- unsigned lpfn;
+ unsigned long fpfn;
+ unsigned long lpfn;
```
**Missing downstream widening:** Note that even with the TTM-level fix (whether this patch or the drm-next version), `struct amdgpu_mem_partition_info` in `amdgpu_gmc.h` still uses `uint32_t` for its `fpfn`/`lpfn`:
```c
struct amdgpu_mem_partition_info {
union {
struct {
uint32_t fpfn;
uint32_t lpfn;
} range;
```
These values feed directly into `places[c].fpfn` at `amdgpu_object.c:123`:
```c
places[c].fpfn = adev->gmc.mem_partitions[mem_id].range.fpfn;
...
places[c].lpfn = adev->gmc.mem_partitions[mem_id].range.lpfn + 1;
```
If the goal is truly 52-bit PA support for AMD GPUs, this downstream struct also needs widening. A follow-up patch addressing `amdgpu_mem_partition_info` would be needed to make the full path consistent.
**No callers updated:** The patch changes the struct definition but doesn't update any callers that may be using `unsigned` or `uint32_t` local variables to hold these values. A grep shows ~31 files touch `fpfn`/`lpfn` across multiple drivers (amdgpu, xe, i915, nouveau, radeon, vmwgfx, qxl, etc.). While many assign literal 0 (safe), some do arithmetic that could be affected by the type change. The patch should have audited these call sites, or at minimum mentioned them in the commit message.
**Verdict:** This patch is redundant with drm-next and uses an inferior type. If the submitter needs 52-bit PA support, they should rebase onto drm-next (which already has the `uint64_t` fix) and submit follow-up patches to widen the AMD-specific structures like `amdgpu_mem_partition_info`.
---
Generated by Claude Code Patch Reviewer
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2026-05-16 2:39 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-05-12 22:31 [PATCH] drm/ttm: Support 52-bit PAs in ttm_place Felix Kuehling
2026-05-13 8:08 ` Christian König
2026-05-13 14:15 ` Kuehling, Felix
2026-05-13 15:42 ` Christian König
2026-05-16 2:38 ` Claude review: " Claude Code Review Bot
2026-05-16 2:39 ` Claude Code Review Bot
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox