Commit 5dc851af authored by Fujii Masao's avatar Fujii Masao

Fix incorrect output from gin_desc().

Previously gin_desc() displayed incorrect output "unknown action 0"
for XLOG_GIN_INSERT and XLOG_GIN_VACUUM_DATA_LEAF_PAGE records with
valid actions. The cause of this problem was that gin_desc() wrongly
used XLogRecGetData() to extract data from those records.
Since they were registered by XLogRegisterBufData(), gin_desc() should
have used XLogRecGetBlockData(), instead, like gin_redo().
Also there were other differences about how to treat XLOG_GIN_INSERT
record between gin_desc() and gin_redo().

This commit fixes gin_desc() routine so that it treats those records
in the same way as gin_redo().

Batch-patch to 9.5 where WAL record format was revamped and
XLogRegisterBufData() was added.

Reported-By: Andres Freund
Reviewed-By: Tom Lane
Discussion: <20160509194645.7lewnpw647zegx2m@alap3.anarazel.de>
parent 38507232
...@@ -87,13 +87,13 @@ gin_desc(StringInfo buf, XLogReaderState *record) ...@@ -87,13 +87,13 @@ gin_desc(StringInfo buf, XLogReaderState *record)
case XLOG_GIN_INSERT: case XLOG_GIN_INSERT:
{ {
ginxlogInsert *xlrec = (ginxlogInsert *) rec; ginxlogInsert *xlrec = (ginxlogInsert *) rec;
char *payload = rec + sizeof(ginxlogInsert);
appendStringInfo(buf, "isdata: %c isleaf: %c", appendStringInfo(buf, "isdata: %c isleaf: %c",
(xlrec->flags & GIN_INSERT_ISDATA) ? 'T' : 'F', (xlrec->flags & GIN_INSERT_ISDATA) ? 'T' : 'F',
(xlrec->flags & GIN_INSERT_ISLEAF) ? 'T' : 'F'); (xlrec->flags & GIN_INSERT_ISLEAF) ? 'T' : 'F');
if (!(xlrec->flags & GIN_INSERT_ISLEAF)) if (!(xlrec->flags & GIN_INSERT_ISLEAF))
{ {
char *payload = rec + sizeof(ginxlogInsert);
BlockNumber leftChildBlkno; BlockNumber leftChildBlkno;
BlockNumber rightChildBlkno; BlockNumber rightChildBlkno;
...@@ -104,22 +104,21 @@ gin_desc(StringInfo buf, XLogReaderState *record) ...@@ -104,22 +104,21 @@ gin_desc(StringInfo buf, XLogReaderState *record)
appendStringInfo(buf, " children: %u/%u", appendStringInfo(buf, " children: %u/%u",
leftChildBlkno, rightChildBlkno); leftChildBlkno, rightChildBlkno);
} }
if (XLogRecHasBlockImage(record, 0))
appendStringInfoString(buf, " (full page image)");
else
{
char *payload = XLogRecGetBlockData(record, 0, NULL);
if (!(xlrec->flags & GIN_INSERT_ISDATA)) if (!(xlrec->flags & GIN_INSERT_ISDATA))
appendStringInfo(buf, " isdelete: %c", appendStringInfo(buf, " isdelete: %c",
(((ginxlogInsertEntry *) payload)->isDelete) ? 'T' : 'F'); (((ginxlogInsertEntry *) payload)->isDelete) ? 'T' : 'F');
else if (xlrec->flags & GIN_INSERT_ISLEAF) else if (xlrec->flags & GIN_INSERT_ISLEAF)
{ desc_recompress_leaf(buf, (ginxlogRecompressDataLeaf *) payload);
ginxlogRecompressDataLeaf *insertData =
(ginxlogRecompressDataLeaf *) payload;
if (XLogRecHasBlockImage(record, 0))
appendStringInfoString(buf, " (full page image)");
else
desc_recompress_leaf(buf, insertData);
}
else else
{ {
ginxlogInsertDataInternal *insertData = (ginxlogInsertDataInternal *) payload; ginxlogInsertDataInternal *insertData =
(ginxlogInsertDataInternal *) payload;
appendStringInfo(buf, " pitem: %u-%u/%u", appendStringInfo(buf, " pitem: %u-%u/%u",
PostingItemGetBlockNumber(&insertData->newitem), PostingItemGetBlockNumber(&insertData->newitem),
...@@ -127,6 +126,7 @@ gin_desc(StringInfo buf, XLogReaderState *record) ...@@ -127,6 +126,7 @@ gin_desc(StringInfo buf, XLogReaderState *record)
ItemPointerGetOffsetNumber(&insertData->newitem.key)); ItemPointerGetOffsetNumber(&insertData->newitem.key));
} }
} }
}
break; break;
case XLOG_GIN_SPLIT: case XLOG_GIN_SPLIT:
{ {
...@@ -144,13 +144,16 @@ gin_desc(StringInfo buf, XLogReaderState *record) ...@@ -144,13 +144,16 @@ gin_desc(StringInfo buf, XLogReaderState *record)
break; break;
case XLOG_GIN_VACUUM_DATA_LEAF_PAGE: case XLOG_GIN_VACUUM_DATA_LEAF_PAGE:
{ {
ginxlogVacuumDataLeafPage *xlrec = (ginxlogVacuumDataLeafPage *) rec;
if (XLogRecHasBlockImage(record, 0)) if (XLogRecHasBlockImage(record, 0))
appendStringInfoString(buf, " (full page image)"); appendStringInfoString(buf, " (full page image)");
else else
{
ginxlogVacuumDataLeafPage *xlrec =
(ginxlogVacuumDataLeafPage *) XLogRecGetBlockData(record, 0, NULL);
desc_recompress_leaf(buf, &xlrec->data); desc_recompress_leaf(buf, &xlrec->data);
} }
}
break; break;
case XLOG_GIN_DELETE_PAGE: case XLOG_GIN_DELETE_PAGE:
/* no further information */ /* no further information */
......
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