]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Fix ./configure checks with __cpuidex() and __cpuid() REL_14_STABLE github/REL_14_STABLE
authorMichael Paquier <michael@paquier.xyz>
Wed, 30 Jul 2025 02:55:53 +0000 (11:55 +0900)
committerMichael Paquier <michael@paquier.xyz>
Wed, 30 Jul 2025 02:55:53 +0000 (11:55 +0900)
commit60953d4cba7cce4a8672b1930d173077ac1130fc
tree59ac412dd536e12e8b013fa57fbd479d5c1ba7f7
parent2dee95bd0cf18d99e4d4778f18a794160a8dcaba
Fix ./configure checks with __cpuidex() and __cpuid()

The configure checks used two incorrect functions when checking the
presence of some routines in an environment:
- __get_cpuidex() for the check of __cpuidex().
- __get_cpuid() for the check of __cpuid().
This means that Postgres has never been able to detect the presence of
these functions, impacting environments where these exist, like Windows.

Simply fixing the function name does not work.  For example, using
configure with MinGW on Windows causes the checks to detect all four of
__get_cpuid(), __get_cpuid_count(), __cpuidex() and __cpuid() to be
available, causing a compilation failure as this messes up with the
MinGW headers as we would include both <intrin.h> and <cpuid.h>.

The Postgres code expects only one in { __get_cpuid() , __cpuid() } and
one in { __get_cpuid_count() , __cpuidex() } to exist.  This commit
reshapes the configure checks to do exactly what meson is doing, which
has been working well for us: check one, then the other, but never allow
both to be detected in a given build.

The logic is wrong since 3dc2d62d0486 and 792752af4eb5 where these
checks have been introduced (the second case is most likely a copy-pasto
coming from the first case), with meson documenting that the configure
checks were broken.  As far as I can see, they are not once applied
consistently with what the code expects, but let's see if the buildfarm
has different something to say.  The comment in meson.build is adjusted
as well, to reflect the new reality.

Author: Lukas Fittl <lukas@fittl.com>
Co-authored-by: Michael Paquier <michael@paquier.xyz>
Discussion: https://postgr.es/m/aIgwNYGVt5aRAqTJ@paquier.xyz
Backpatch-through: 13
configure
configure.ac