mirror of
https://github.com/postgres/postgres.git
synced 2026-03-17 16:12:13 -04:00
free space information is stored in a dedicated FSM relation fork, with each relation (except for hash indexes; they don't use FSM). This eliminates the max_fsm_relations and max_fsm_pages GUC options; remove any trace of them from the backend, initdb, and documentation. Rewrite contrib/pg_freespacemap to match the new FSM implementation. Also introduce a new variant of the get_raw_page(regclass, int4, int4) function in contrib/pageinspect that let's you to return pages from any relation fork, and a new fsm_page_contents() function to inspect the new FSM pages.
36 lines
810 B
C
36 lines
810 B
C
/*
|
|
* rmgr.h
|
|
*
|
|
* Resource managers definition
|
|
*
|
|
* $PostgreSQL: pgsql/src/include/access/rmgr.h,v 1.18 2008/09/30 10:52:13 heikki Exp $
|
|
*/
|
|
#ifndef RMGR_H
|
|
#define RMGR_H
|
|
|
|
typedef uint8 RmgrId;
|
|
|
|
/*
|
|
* Built-in resource managers
|
|
*
|
|
* Note: RM_MAX_ID could be as much as 255 without breaking the XLOG file
|
|
* format, but we keep it small to minimize the size of RmgrTable[].
|
|
*/
|
|
#define RM_XLOG_ID 0
|
|
#define RM_XACT_ID 1
|
|
#define RM_SMGR_ID 2
|
|
#define RM_CLOG_ID 3
|
|
#define RM_DBASE_ID 4
|
|
#define RM_TBLSPC_ID 5
|
|
#define RM_MULTIXACT_ID 6
|
|
#define RM_FREESPACE_ID 7
|
|
#define RM_HEAP2_ID 9
|
|
#define RM_HEAP_ID 10
|
|
#define RM_BTREE_ID 11
|
|
#define RM_HASH_ID 12
|
|
#define RM_GIN_ID 13
|
|
#define RM_GIST_ID 14
|
|
#define RM_SEQ_ID 15
|
|
#define RM_MAX_ID RM_SEQ_ID
|
|
|
|
#endif /* RMGR_H */
|