1 /*-------------------------------------------------------------------------
4 * Functions to investigate FSM pages
6 * These functions are restricted to superusers for the fear of introducing
7 * security holes if the input checking isn't as water-tight as it should.
8 * You'd need to be superuser to obtain a raw page image anyway, so
9 * there's hardly any use case for using these without superuser-rights
12 * Copyright (c) 2007-2014, PostgreSQL Global Development Group
15 * contrib/pageinspect/fsmfuncs.c
17 *-------------------------------------------------------------------------
23 #include "lib/stringinfo.h"
24 #include "miscadmin.h"
25 #include "storage/fsm_internals.h"
26 #include "utils/builtins.h"
29 * Dumps the contents of a FSM page.
31 PG_FUNCTION_INFO_V1(fsm_page_contents);
34 fsm_page_contents(PG_FUNCTION_ARGS)
36 bytea *raw_page = PG_GETARG_BYTEA_P(0);
43 (errcode(ERRCODE_INSUFFICIENT_PRIVILEGE),
44 (errmsg("must be superuser to use raw page functions"))));
46 fsmpage = (FSMPage) PageGetContents(VARDATA(raw_page));
48 initStringInfo(&sinfo);
50 for (i = 0; i < NodesPerPage; i++)
52 if (fsmpage->fp_nodes[i] != 0)
53 appendStringInfo(&sinfo, "%d: %d\n", i, fsmpage->fp_nodes[i]);
55 appendStringInfo(&sinfo, "fp_next_slot: %d\n", fsmpage->fp_next_slot);
57 PG_RETURN_TEXT_P(cstring_to_text_with_len(sinfo.data, sinfo.len));