pgsql: Add optimized C string hashing

Поиск
Список
Период
Сортировка
От John Naylor
Тема pgsql: Add optimized C string hashing
Дата
Msg-id E1rQhvE-0026ts-Hs@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Add optimized C string hashing

Given an already-initialized hash state and a NUL-terminated string,
accumulate the hash of the string into the hash state and return the
length for the caller to (optionally) save for the finalizer. This
avoids a strlen call.

If the string pointer is aligned, we can use a word-at-a-time
algorithm for NUL lookahead. The aligned case is only used on 64-bit
platforms, since it's not worth the extra complexity for 32-bit.

Handling the tail of the string after finishing the word-wise loop
was inspired by NetBSD's strlen(), but no code was taken since that
is written in assembly language.

As demonstration, use this in the search path cache. This brings the
general case performance closer to the special case optimization done
in commit a86c61c9ee. There are other places that could benefit, but
that is left for future work.

Jeff Davis and John Naylor
Reviewed by Heikki Linnakangas, Jian He, Junwang Zhao

Discussion: https://postgr.es/m/3820f030fd008ff14134b3e9ce5cc6dd623ed479.camel%40j-davis.com
Discussion: https://postgr.es/m/b40292c99e623defe5eadedab1d438cf51a4107c.camel%40j-davis.com

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/0aba2554409ee3251d7558567edd114d8ed36dcc

Modified Files
--------------
src/backend/catalog/namespace.c      |  20 ++++--
src/include/common/hashfn_unstable.h | 130 +++++++++++++++++++++++++++++++++++
2 files changed, 145 insertions(+), 5 deletions(-)


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

Предыдущее
От: John Naylor
Дата:
Сообщение: pgsql: Add inline incremental hash functions for in-memory use
Следующее
От: John Naylor
Дата:
Сообщение: pgsql: Fixed misspelled byteswap function for big endian machines