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 по дате отправления: