diff options
author | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2024-03-12 15:31:02 +0200 |
---|---|---|
committer | Heikki Linnakangas <heikki.linnakangas@iki.fi> | 2024-03-12 15:31:02 +0200 |
commit | cb9663e20dc2ddc904660d12638f6c82af7b420e (patch) | |
tree | 83e5b904fb78ac148166721162c9b12f8ef04cde | |
parent | 4945e4ed4a72c3ff41560ccef722c3d70ae07dbb (diff) | |
download | postgresql-cb9663e20dc2ddc904660d12638f6c82af7b420e.tar.gz postgresql-cb9663e20dc2ddc904660d12638f6c82af7b420e.zip |
Fix copying SockAddr struct
Valgrind alerted about accessing uninitialized bytes after commit
4945e4ed4a:
==700242== VALGRINDERROR-BEGIN
==700242== Conditional jump or move depends on uninitialised value(s)
==700242== at 0x6D8A2A: getnameinfo_unix (ip.c:253)
==700242== by 0x6D8BD1: pg_getnameinfo_all (ip.c:122)
==700242== by 0x4B3EB6: BackendInitialize (postmaster.c:4266)
==700242== by 0x4B684E: BackendStartup (postmaster.c:4114)
==700242== by 0x4B6986: ServerLoop (postmaster.c:1780)
==700242== by 0x4B80CA: PostmasterMain (postmaster.c:1478)
==700242== by 0x3F7424: main (main.c:197)
==700242== Uninitialised value was created by a stack allocation
==700242== at 0x4B6934: ServerLoop (postmaster.c:1737)
==700242==
==700242== VALGRINDERROR-END
That was because the SockAddr struct was not copied correctly.
Per buildfarm animal "skink".
-rw-r--r-- | src/backend/libpq/pqcomm.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/backend/libpq/pqcomm.c b/src/backend/libpq/pqcomm.c index 9dfdccdd043..6497100a1a4 100644 --- a/src/backend/libpq/pqcomm.c +++ b/src/backend/libpq/pqcomm.c @@ -177,7 +177,8 @@ pq_init(ClientSocket *client_sock) /* allocate the Port struct and copy the ClientSocket contents to it */ port = palloc0(sizeof(Port)); port->sock = client_sock->sock; - port->raddr = client_sock->raddr; + memcpy(&port->raddr.addr, &client_sock->raddr.addr, client_sock->raddr.salen); + port->raddr.salen = client_sock->raddr.salen; /* fill in the server (local) address */ port->laddr.salen = sizeof(port->laddr.addr); |