Skip to content

Commit f1d5a94

Browse files
Set type identifier on BIO
In OpenSSL there are two types of BIO's (I/O abstractions): source/sink and filters. A source/sink BIO is a source and/or sink of data, ie one acting on a socket or a file. A filter BIO takes a stream of input from another BIO and transforms it. In order for BIO_find_type() to be able to traverse the chain of BIO's and correctly find all BIO's of a certain type they shall have the type bit set accordingly, source/sink BIO's (what PostgreSQL implements) use BIO_TYPE_SOURCE_SINK and filter BIO's use BIO_TYPE_FILTER. In addition to these, file descriptor based BIO's should have the descriptor bit set, BIO_TYPE_DESCRIPTOR. The PostgreSQL implementation didn't set the type bits, which went unnoticed for a long time as it's only really relevant for code auditing the OpenSSL installation, or doing similar tasks. It is required by the API though, so this fixes it. Backpatch through 9.6 as this has been wrong for a long time. Author: Itamar Gafni Discussion: https://postgr.es/m/SN6PR06MB39665EC10C34BB20956AE4578AF39@SN6PR06MB3966.namprd06.prod.outlook.com Backpatch-through: 9.6
1 parent b889d6c commit f1d5a94

File tree

2 files changed

+2
-0
lines changed

2 files changed

+2
-0
lines changed

src/backend/libpq/be-secure-openssl.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -723,6 +723,7 @@ my_BIO_s_socket(void)
723723
my_bio_index = BIO_get_new_index();
724724
if (my_bio_index == -1)
725725
return NULL;
726+
my_bio_index |= (BIO_TYPE_DESCRIPTOR | BIO_TYPE_SOURCE_SINK);
726727
my_bio_methods = BIO_meth_new(my_bio_index, "PostgreSQL backend socket");
727728
if (!my_bio_methods)
728729
return NULL;

src/interfaces/libpq/fe-secure-openssl.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1531,6 +1531,7 @@ my_BIO_s_socket(void)
15311531
my_bio_index = BIO_get_new_index();
15321532
if (my_bio_index == -1)
15331533
return NULL;
1534+
my_bio_index |= (BIO_TYPE_DESCRIPTOR | BIO_TYPE_SOURCE_SINK);
15341535
my_bio_methods = BIO_meth_new(my_bio_index, "libpq socket");
15351536
if (!my_bio_methods)
15361537
return NULL;

0 commit comments

Comments
 (0)