> On Mar 6, 2026, at 06:49, Michael Paquier <[email protected]> wrote:
>
> On Thu, Mar 05, 2026 at 04:25:57PM -0600, Sami Imseih wrote:
>> With the above assert in place, the usable_pages of 879 ars you have
>> in test_dsa.c crashes
>> due to the assertion failure.
>
> Yep, the assertion looks useful to have in place.
>
While debugging the code, I used the same Assert, which helped quickly trigger
the bug. Without the Assert, even if an OOB happens, it might not immediately
crash.
But now that the bug has been identified and fixed, and the function is
self-contained, I’m not sure how much the Assert would still help. Unless we
are not sure whether the fix really works, otherwise I don’t think the Assert
is necessary.
However, this is not a strong objection. If we do want to add the Assert, I
notice the expression MAXALIGN(sizeof(dsa_segment_header)) +
MAXALIGN(sizeof(FreePageManager)) appears multiple times, and the Assert
actually uses it as well. We could add a local variable like:
```
size_t metadata_fixed_bytes =
MAXALIGN(sizeof(dsa_segment_header)) +
MAXALIGN(sizeof(FreePageManager));
```
That would help reduce code redundancy.
Best regards,
--
Chao Li (Evan)
HighGo Software Co., Ltd.
https://www.highgo.com/