From: Michael Paquier Date: Mon, 16 Feb 2026 23:41:26 +0000 (+0900) Subject: hstore: Fix NULL pointer dereference with receive function X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a6f823e77835a075265bc6accce0a17370ed6db5;p=thirdparty%2Fpostgresql.git hstore: Fix NULL pointer dereference with receive function The receive function of hstore was not able to handle correctly duplicate key values when a new duplicate links to a NULL value, where a pfree() could be attempted on a NULL pointer, crashing due to a pointer dereference. This problem would happen for a COPY BINARY, when stacking values like that: aa => 5 aa => null The second key/value pair is discarded and pfree() calls are attempted on its key and its value, leading to a pointer dereference for the value part as the value is NULL. The first key/value pair takes priority when a duplicate is found. Per offline report. Reported-by: "Anemone" Reported-by: "A1ex" Backpatch-through: 14 --- diff --git a/contrib/hstore/hstore_io.c b/contrib/hstore/hstore_io.c index 9cdfcb5daa0..9b72efb8674 100644 --- a/contrib/hstore/hstore_io.c +++ b/contrib/hstore/hstore_io.c @@ -385,7 +385,8 @@ hstoreUniquePairs(Pairs *a, int32 l, int32 *buflen) if (ptr->needfree) { pfree(ptr->key); - pfree(ptr->val); + if (ptr->val != NULL) + pfree(ptr->val); } } else