From: Tom Lane Date: Fri, 16 May 2014 19:18:09 +0000 (-0400) Subject: Fix a second cause of undersized pallocs for btree_gist indexes on macaddr. X-Git-Tag: REL9_4_BETA2~173 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=39586bc1e971c136c4487b26eb7334dbbe23b102;p=postgresql Fix a second cause of undersized pallocs for btree_gist indexes on macaddr. gbt_macad_union also allocated 12-byte structs where we really need 16. Per report from Andres Freund. No back-patch since there's no current risk of a real problem. --- diff --git a/contrib/btree_gist/btree_macaddr.c b/contrib/btree_gist/btree_macaddr.c index 244b95154b..ed58a1b742 100644 --- a/contrib/btree_gist/btree_macaddr.c +++ b/contrib/btree_gist/btree_macaddr.c @@ -12,6 +12,7 @@ typedef struct { macaddr lower; macaddr upper; + char pad[4]; /* make struct size = sizeof(gbtreekey16) */ } macKEY; /* @@ -143,7 +144,7 @@ Datum gbt_macad_union(PG_FUNCTION_ARGS) { GistEntryVector *entryvec = (GistEntryVector *) PG_GETARG_POINTER(0); - void *out = palloc(sizeof(macKEY)); + void *out = palloc0(sizeof(macKEY)); *(int *) PG_GETARG_POINTER(1) = sizeof(macKEY); PG_RETURN_POINTER(gbt_num_union((void *) out, entryvec, &tinfo));