aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--contrib/amcheck/verify_heapam.c20
-rw-r--r--src/bin/pg_amcheck/t/004_verify_heapam.pl11
2 files changed, 14 insertions, 17 deletions
diff --git a/contrib/amcheck/verify_heapam.c b/contrib/amcheck/verify_heapam.c
index 1dc9d89f306..ce3114f4e6c 100644
--- a/contrib/amcheck/verify_heapam.c
+++ b/contrib/amcheck/verify_heapam.c
@@ -624,17 +624,6 @@ verify_heapam(PG_FUNCTION_ARGS)
(unsigned) nextoffnum));
}
- /*
- * Redirects are created by updates, so successor should be
- * the result of an update.
- */
- if ((next_htup->t_infomask & HEAP_UPDATED) == 0)
- {
- report_corruption(&ctx,
- psprintf("redirected line pointer points to a non-heap-updated tuple at offset %u",
- (unsigned) nextoffnum));
- }
-
/* HOT chains should not intersect. */
if (predecessor[nextoffnum] != InvalidOffsetNumber)
{
@@ -954,6 +943,15 @@ check_tuple_header(HeapCheckContext *ctx)
*/
}
+ if (HeapTupleHeaderIsHeapOnly(tuphdr) &&
+ ((tuphdr->t_infomask & HEAP_UPDATED) == 0))
+ {
+ report_corruption(ctx,
+ psprintf("tuple is heap only, but not the result of an update"));
+
+ /* Here again, we can still perform further checks. */
+ }
+
if (infomask & HEAP_HASNULL)
expected_hoff = MAXALIGN(SizeofHeapTupleHeader + BITMAPLEN(ctx->natts));
else
diff --git a/src/bin/pg_amcheck/t/004_verify_heapam.pl b/src/bin/pg_amcheck/t/004_verify_heapam.pl
index cc4aa4af875..90ba59ec0b7 100644
--- a/src/bin/pg_amcheck/t/004_verify_heapam.pl
+++ b/src/bin/pg_amcheck/t/004_verify_heapam.pl
@@ -617,12 +617,10 @@ for (my $tupidx = 0; $tupidx < $ROWCOUNT; $tupidx++)
}
elsif ($offnum == 17)
{
- # at offnum 19 we will unset HEAP_ONLY_TUPLE and HEAP_UPDATED flags.
+ # at offnum 19 we will unset HEAP_ONLY_TUPLE flag
die "offnum $offnum should be a redirect" if defined $tup;
push @expected,
qr/${header}redirected line pointer points to a non-heap-only tuple at offset \d+/;
- push @expected,
- qr/${header}redirected line pointer points to a non-heap-updated tuple at offset \d+/;
}
elsif ($offnum == 18)
{
@@ -637,10 +635,9 @@ for (my $tupidx = 0; $tupidx < $ROWCOUNT; $tupidx++)
}
elsif ($offnum == 19)
{
- # unset HEAP_ONLY_TUPLE and HEAP_UPDATED flag, so that update chain
- # validation will complain about offset 17
+ # unset HEAP_ONLY_TUPLE flag, so that update chain validation will
+ # complain about offset 17
$tup->{t_infomask2} &= ~HEAP_ONLY_TUPLE;
- $tup->{t_infomask} &= ~HEAP_UPDATED;
}
elsif ($offnum == 22)
{
@@ -688,6 +685,8 @@ for (my $tupidx = 0; $tupidx < $ROWCOUNT; $tupidx++)
$tup->{t_infomask2} |= HEAP_ONLY_TUPLE;
push @expected,
qr/${header}tuple is root of chain but is marked as heap-only tuple/;
+ push @expected,
+ qr/${header}tuple is heap only, but not the result of an update/;
}
elsif ($offnum == 33)
{