Em ter., 12 de nov. de 2024 às 21:33, Michael Paquier <mich...@paquier.xyz>
escreveu:

> On Tue, Nov 12, 2024 at 01:32:36PM -0300, Ranier Vilela wrote:
> > See v1_allzeros_small.c attached.
>
> In your pg_memory_is_all_zeros_v11:
>     while (((uintptr_t) p & (sizeof(size_t) - 1)) != 0)
>     {
>         if (p == end)
>             return true;
>
>         if (*p++ != 0)
>             return false;
>     }
>
>     if (len > sizeof(size_t) * 8)
>     {
>       for (; p < aligned_end - (sizeof(size_t) * 7); p += sizeof(size_t) *
> 8)
>       {
>           if ((((size_t *) p)[0] != 0) | (((size_t *) p)[1] != 0) |
>               (((size_t *) p)[2] != 0) | (((size_t *) p)[3] != 0) |
>               (((size_t *) p)[4] != 0) | (((size_t *) p)[5] != 0) |
>               (((size_t *) p)[6] != 0) | (((size_t *) p)[7] != 0))
>               return false;
>       }
>     }
>
> If I'm reading that right, this could still read a couple of bytes
> past the wanted memory area.

Yeah, this is possible.


> For example, imagine a case of 65 bytes
> with a location a bit unaligned (more than 2 bytes).  You'd want to
> check the remaining size after the first loop, not the initial one.
>
> I'd be OK to have a quick loop for the less-than-64-byte case rather
> than more checks depending on sizeof(size_t) spread, like Bertrand is
> suggesting.

I'm ok too. Maybe we are trying to optimize early.

best regards,
Ranier Vilela

Reply via email to