Dear PostgreSQL Developers,
I have identified a potential integer overflow issue in the binary search implementation within the DSA size class lookup code.
Issue Description
In the current implementation, the calculation of mid
is performed as:
uint16 mid = (max + min) / 2;
Since both max
and min
are of type uint16
, adding them together may exceed 65535
, leading to an overflow and incorrect behavior in the binary search logic. This could result in incorrect indexing into the dsa_size_classes
array.
Proposed Fix
To prevent this overflow, we should use the alternative calculation method:
uint16 mid = min + (max - min) / 2;
This approach ensures that (max - min)
does not exceed 65535
, preventing the addition from overflowing while still correctly computing the middle index.
Patch
A patch implementing this fix is attached.