pgsql: Use unnamed POSIX semaphores, if available, on Linux and FreeBSD - Mailing list pgsql-committers

From Tom Lane
Subject pgsql: Use unnamed POSIX semaphores, if available, on Linux and FreeBSD
Date
Msg-id E1btMCP-00088P-8s@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Use unnamed POSIX semaphores, if available, on Linux and FreeBSD.

We've had support for using unnamed POSIX semaphores instead of System V
semaphores for quite some time, but it was not used by default on any
platform.  Since many systems have rather small limits on the number of
SysV semaphores allowed, it seems desirable to switch to POSIX semaphores
where they're available and don't create performance or kernel resource
problems.  Experimentation by me shows that unnamed POSIX semaphores
are at least as good as SysV semaphores on Linux, and we previously had
a report from Maksym Sobolyev that FreeBSD is significantly worse with
SysV semaphores than POSIX ones.  So adjust those two platforms to use
unnamed POSIX semaphores, if configure can find the necessary library
functions.  If this goes well, we may switch other platforms as well,
but it would be advisable to test them individually first.

It's not currently contemplated that we'd encourage users to select
a semaphore API for themselves, but anyone who wants to experiment
can add PREFERRED_SEMAPHORES=UNNAMED_POSIX (or NAMED_POSIX, or SYSV)
to their configure command line to do so.

I also tweaked configure to report which API it's selected, mainly
so that we can tell that from buildfarm reports.

I did not touch the user documentation's discussion about semaphores;
that will need some adjustment once the dust settles.

Discussion: <8536.1475704230@sss.pgh.pa.us>

Branch
------
master

Details
-------
http://git.postgresql.org/pg/commitdiff/ecb0d20a9d2e09b7112d3b192047f711f9ff7e59

Modified Files
--------------
configure            | 125 +++++++++++++++++++++++++++++++++++++++++++++++++++
configure.in         |  13 ++++++
src/template/freebsd |   5 +++
src/template/linux   |   5 +++
4 files changed, 148 insertions(+)


pgsql-committers by date:

Previous
From: Tom Lane
Date:
Subject: pgsql: Fix incorrect handling of polymorphic aggregates used as window
Next
From: Peter Eisentraut
Date:
Subject: pgsql: Add a noreturn attribute to help static analyzers