smgr.h 5.3 KB
Newer Older
1 2
/*-------------------------------------------------------------------------
 *
3
 * smgr.h
4
 *	  storage manager switch public interface declarations.
5 6
 *
 *
7
 * Portions Copyright (c) 1996-2010, PostgreSQL Global Development Group
B
Add:  
Bruce Momjian 已提交
8
 * Portions Copyright (c) 1994, Regents of the University of California
9
 *
10
 * $PostgreSQL: pgsql/src/include/storage/smgr.h,v 1.70 2010/02/09 21:43:30 tgl Exp $
11 12 13 14 15 16
 *
 *-------------------------------------------------------------------------
 */
#ifndef SMGR_H
#define SMGR_H

17
#include "access/xlog.h"
18
#include "fmgr.h"
19
#include "storage/block.h"
20 21 22 23 24 25 26 27 28 29
#include "storage/relfilenode.h"


/*
 * smgr.c maintains a table of SMgrRelation objects, which are essentially
 * cached file handles.  An SMgrRelation is created (if not already present)
 * by smgropen(), and destroyed by smgrclose().  Note that neither of these
 * operations imply I/O, they just create or destroy a hashtable entry.
 * (But smgrclose() may release associated resources, such as OS-level file
 * descriptors.)
30 31 32
 *
 * An SMgrRelation may have an "owner", which is just a pointer to it from
 * somewhere else; smgr.c will clear this pointer if the SMgrRelation is
B
Bruce Momjian 已提交
33
 * closed.	We use this to avoid dangling pointers from relcache to smgr
34 35 36
 * without having to make the smgr explicitly aware of relcache.  There
 * can't be more than one "owner" pointer per SMgrRelation, but that's
 * all we need.
37 38 39 40
 */
typedef struct SMgrRelationData
{
	/* rnode is the hashtable lookup key, so it must be first! */
B
Bruce Momjian 已提交
41
	RelFileNode smgr_rnode;		/* relation physical identifier */
42

43 44 45
	/* pointer to owning pointer, or NULL if none */
	struct SMgrRelationData **smgr_owner;

46 47 48 49 50 51 52 53 54 55 56
	/*
	 * These next three fields are not actually used or manipulated by smgr,
	 * except that they are reset to InvalidBlockNumber upon a cache flush
	 * event (in particular, upon truncation of the relation).  Higher levels
	 * store cached state here so that it will be reset when truncation
	 * happens.  In all three cases, InvalidBlockNumber means "unknown".
	 */
	BlockNumber smgr_targblock;		/* current insertion target block */
	BlockNumber smgr_fsm_nblocks;	/* last known size of fsm fork */
	BlockNumber smgr_vm_nblocks;	/* last known size of vm fork */

57
	/* additional public fields may someday exist here */
58

59 60
	/*
	 * Fields below here are intended to be private to smgr.c and its
B
Bruce Momjian 已提交
61
	 * submodules.	Do not touch them from elsewhere.
62 63
	 */
	int			smgr_which;		/* storage manager selector */
64

65 66
	/* for md.c; NULL for forks that are not open */
	struct _MdfdVec *md_fd[MAX_FORKNUM + 1];
67
} SMgrRelationData;
68

69 70 71 72 73
typedef SMgrRelationData *SMgrRelation;


extern void smgrinit(void);
extern SMgrRelation smgropen(RelFileNode rnode);
74
extern bool smgrexists(SMgrRelation reln, ForkNumber forknum);
75
extern void smgrsetowner(SMgrRelation *owner, SMgrRelation reln);
76 77 78
extern void smgrclose(SMgrRelation reln);
extern void smgrcloseall(void);
extern void smgrclosenode(RelFileNode rnode);
79
extern void smgrcreate(SMgrRelation reln, ForkNumber forknum, bool isRedo);
80
extern void smgrdounlink(SMgrRelation reln, ForkNumber forknum,
81 82 83
			 bool isTemp, bool isRedo);
extern void smgrextend(SMgrRelation reln, ForkNumber forknum,
		   BlockNumber blocknum, char *buffer, bool isTemp);
84
extern void smgrprefetch(SMgrRelation reln, ForkNumber forknum,
85
			 BlockNumber blocknum);
86
extern void smgrread(SMgrRelation reln, ForkNumber forknum,
87
		 BlockNumber blocknum, char *buffer);
88
extern void smgrwrite(SMgrRelation reln, ForkNumber forknum,
89
		  BlockNumber blocknum, char *buffer, bool isTemp);
90 91
extern BlockNumber smgrnblocks(SMgrRelation reln, ForkNumber forknum);
extern void smgrtruncate(SMgrRelation reln, ForkNumber forknum,
92
			 BlockNumber nblocks, bool isTemp);
93
extern void smgrimmedsync(SMgrRelation reln, ForkNumber forknum);
94
extern void smgrpreckpt(void);
95
extern void smgrsync(void);
96
extern void smgrpostckpt(void);
97

98 99 100 101

/* internals: move me elsewhere -- ay 7/94 */

/* in md.c */
102
extern void mdinit(void);
103 104 105 106 107
extern void mdclose(SMgrRelation reln, ForkNumber forknum);
extern void mdcreate(SMgrRelation reln, ForkNumber forknum, bool isRedo);
extern bool mdexists(SMgrRelation reln, ForkNumber forknum);
extern void mdunlink(RelFileNode rnode, ForkNumber forknum, bool isRedo);
extern void mdextend(SMgrRelation reln, ForkNumber forknum,
108
		 BlockNumber blocknum, char *buffer, bool isTemp);
109
extern void mdprefetch(SMgrRelation reln, ForkNumber forknum,
110
		   BlockNumber blocknum);
111
extern void mdread(SMgrRelation reln, ForkNumber forknum, BlockNumber blocknum,
112
	   char *buffer);
113
extern void mdwrite(SMgrRelation reln, ForkNumber forknum,
114
		BlockNumber blocknum, char *buffer, bool isTemp);
115 116
extern BlockNumber mdnblocks(SMgrRelation reln, ForkNumber forknum);
extern void mdtruncate(SMgrRelation reln, ForkNumber forknum,
117
		   BlockNumber nblocks, bool isTemp);
118
extern void mdimmedsync(SMgrRelation reln, ForkNumber forknum);
119
extern void mdpreckpt(void);
120
extern void mdsync(void);
121
extern void mdpostckpt(void);
122

123
extern void SetForwardFsyncRequests(void);
124
extern void RememberFsyncRequest(RelFileNode rnode, ForkNumber forknum,
125
					 BlockNumber segno);
126
extern void ForgetRelationFsyncRequests(RelFileNode rnode, ForkNumber forknum);
127
extern void ForgetDatabaseFsyncRequests(Oid dbid);
128

B
Bruce Momjian 已提交
129
/* smgrtype.c */
130 131 132 133
extern Datum smgrout(PG_FUNCTION_ARGS);
extern Datum smgrin(PG_FUNCTION_ARGS);
extern Datum smgreq(PG_FUNCTION_ARGS);
extern Datum smgrne(PG_FUNCTION_ARGS);
134

135
#endif   /* SMGR_H */