Commit e1a93dd6 authored by Tom Lane's avatar Tom Lane

tqueue.c's record-typmod hashtables need the HASH_BLOBS option.

The keys are integers, not strings.  The code accidentally worked on
little-endian machines, at least up to 256 distinct record types within
a session, but failed utterly on big-endian.  This was unexpectedly
exposed by a test case added by commit 4452000f, which apparently is the
only parallelizable query in the regression suite that uses more than one
anonymous record type.  Fortunately, buildfarm member mandrill is
big-endian and is running with force_parallel_mode on, so it failed.
parent 69995c3b
...@@ -402,7 +402,8 @@ tqueueSendTypmodInfo(TQueueDestReceiver *tqueue, int typmod, ...@@ -402,7 +402,8 @@ tqueueSendTypmodInfo(TQueueDestReceiver *tqueue, int typmod,
ctl.entrysize = sizeof(int); ctl.entrysize = sizeof(int);
ctl.hcxt = TopMemoryContext; ctl.hcxt = TopMemoryContext;
tqueue->recordhtab = hash_create("tqueue record hashtable", tqueue->recordhtab = hash_create("tqueue record hashtable",
100, &ctl, HASH_ELEM | HASH_CONTEXT); 100, &ctl,
HASH_ELEM | HASH_BLOBS | HASH_CONTEXT);
} }
/* Have we already seen this record type? If not, must report it. */ /* Have we already seen this record type? If not, must report it. */
...@@ -877,7 +878,8 @@ TupleQueueHandleControlMessage(TupleQueueReader *reader, Size nbytes, ...@@ -877,7 +878,8 @@ TupleQueueHandleControlMessage(TupleQueueReader *reader, Size nbytes,
ctl.entrysize = sizeof(RecordTypemodMap); ctl.entrysize = sizeof(RecordTypemodMap);
ctl.hcxt = CurTransactionContext; ctl.hcxt = CurTransactionContext;
reader->typmodmap = hash_create("typmodmap hashtable", reader->typmodmap = hash_create("typmodmap hashtable",
100, &ctl, HASH_ELEM | HASH_CONTEXT); 100, &ctl,
HASH_ELEM | HASH_BLOBS | HASH_CONTEXT);
} }
/* Create map entry. */ /* Create map entry. */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment