Re: Improve conditional compilation for direct I/O alignment checks

Поиск
Список
Период
Сортировка
От Peter Eisentraut
Тема Re: Improve conditional compilation for direct I/O alignment checks
Дата
Msg-id 84e2783f-8082-4fd9-bf5f-31982caf9aff@eisentraut.org
обсуждение исходный текст
Ответ на Improve conditional compilation for direct I/O alignment checks  (Junwang Zhao <zhjwpku@gmail.com>)
Список pgsql-hackers
On 26.05.24 09:16, Junwang Zhao wrote:
> This patch refactors the alignment checks for direct I/O to preprocess phase,
> thereby reducing some CPU cycles.

This patch replaces for example

     if (PG_O_DIRECT != 0 && PG_IO_ALIGN_SIZE <= BLCKSZ)
         Assert((uintptr_t) buffer == TYPEALIGN(PG_IO_ALIGN_SIZE, buffer));

with

     #if PG_O_DIRECT != 0 && PG_IO_ALIGN_SIZE <= BLCKSZ
         Assert((uintptr_t) buffer == TYPEALIGN(PG_IO_ALIGN_SIZE, buffer));
     #endif

You appear to be assuming that this saves some CPU cycles.  But this is 
not the case.  The compiler will remove the unused code in the first 
case because all the constants in the if expression are known at 
compile-time.



В списке pgsql-hackers по дате отправления:

Предыдущее
От: Daniel Gustafsson
Дата:
Сообщение: Re: DROP OWNED BY fails to clean out pg_init_privs grants
Следующее
От: David Rowley
Дата:
Сообщение: Re: Speed up JSON escape processing with SIMD plus other optimisations