mirror of
https://github.com/postgres/postgres.git
synced 2025-07-30 11:03:19 +03:00
pageinspect: Improve page_header() for pages of 32kB
ld_upper, ld_lower, pd_special and the page size have been using smallint as return type, which could cause those fields to return negative values in certain cases for builds configures with a page size of 32kB. Bump pageinspect to 1.10. page_header() is able to handle the correct return type of those fields at runtime when using an older version of the extension, with some tests are added to cover that. Author: Quan Zongliang Reviewed-by: Michael Paquier, Bharath Rupireddy Discussion: https://postgr.es/m/8b8ec36e-61fe-14f9-005d-07bc85aa4eed@yeah.net
This commit is contained in:
@ -296,10 +296,33 @@ page_header(PG_FUNCTION_ARGS)
|
||||
values[0] = LSNGetDatum(lsn);
|
||||
values[1] = UInt16GetDatum(page->pd_checksum);
|
||||
values[2] = UInt16GetDatum(page->pd_flags);
|
||||
values[3] = UInt16GetDatum(page->pd_lower);
|
||||
values[4] = UInt16GetDatum(page->pd_upper);
|
||||
values[5] = UInt16GetDatum(page->pd_special);
|
||||
values[6] = UInt16GetDatum(PageGetPageSize(page));
|
||||
|
||||
/* pageinspect >= 1.10 uses int4 instead of int2 for those fields */
|
||||
switch (TupleDescAttr(tupdesc, 3)->atttypid)
|
||||
{
|
||||
case INT2OID:
|
||||
Assert(TupleDescAttr(tupdesc, 4)->atttypid == INT2OID &&
|
||||
TupleDescAttr(tupdesc, 5)->atttypid == INT2OID &&
|
||||
TupleDescAttr(tupdesc, 6)->atttypid == INT2OID);
|
||||
values[3] = UInt16GetDatum(page->pd_lower);
|
||||
values[4] = UInt16GetDatum(page->pd_upper);
|
||||
values[5] = UInt16GetDatum(page->pd_special);
|
||||
values[6] = UInt16GetDatum(PageGetPageSize(page));
|
||||
break;
|
||||
case INT4OID:
|
||||
Assert(TupleDescAttr(tupdesc, 4)->atttypid == INT4OID &&
|
||||
TupleDescAttr(tupdesc, 5)->atttypid == INT4OID &&
|
||||
TupleDescAttr(tupdesc, 6)->atttypid == INT4OID);
|
||||
values[3] = Int32GetDatum(page->pd_lower);
|
||||
values[4] = Int32GetDatum(page->pd_upper);
|
||||
values[5] = Int32GetDatum(page->pd_special);
|
||||
values[6] = Int32GetDatum(PageGetPageSize(page));
|
||||
break;
|
||||
default:
|
||||
elog(ERROR, "incorrect output types");
|
||||
break;
|
||||
}
|
||||
|
||||
values[7] = UInt16GetDatum(PageGetPageLayoutVersion(page));
|
||||
values[8] = TransactionIdGetDatum(page->pd_prune_xid);
|
||||
|
||||
|
Reference in New Issue
Block a user