pgsql: Fix race condition with BIO methods initialization in libpq with - Mailing list pgsql-committers

From Michael Paquier
Subject pgsql: Fix race condition with BIO methods initialization in libpq with
Date
Msg-id E1r7Pgb-007QLh-L1@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Fix race condition with BIO methods initialization in libpq with threads

The libpq code in charge of creating per-connection SSL objects was
prone to a race condition when loading the custom BIO methods needed by
my_SSL_set_fd().  As BIO methods are stored as a static variable, the
initialization of a connection could fail because it could be possible
to have one thread refer to my_bio_methods while it is being manipulated
by a second concurrent thread.

This error has been introduced by 8bb14cdd33de, that has removed
ssl_config_mutex around the call of my_SSL_set_fd(), that itself sets
the custom BIO methods used in libpq.  Like previously, the BIO method
initialization is now protected by the existing ssl_config_mutex, itself
initialized earlier for WIN32.

While on it, document that my_bio_methods is protected by
ssl_config_mutex, as this can be easy to miss.

Reported-by: Willi Mann
Author: Willi Mann, Michael Paquier
Discussion: https://postgr.es/m/e77abc4c-4d03-4058-a9d7-ef0035657e04@celonis.com
Backpatch-through: 12

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/01eca6a913c4997c17e1569898f14cf611bff647

Modified Files
--------------
src/interfaces/libpq/fe-secure-openssl.c | 64 +++++++++++++++++++++-----------
1 file changed, 42 insertions(+), 22 deletions(-)


pgsql-committers by date:

Previous
From: Alexander Korotkov
Date:
Subject: pgsql: Display length and bounds histograms in pg_stats
Next
From: Alexander Korotkov
Date:
Subject: pgsql: Track statement entry timestamp in contrib/pg_stat_statements