LCOV - code coverage report
Current view: top level - src/include/storage - smgr.h (source / functions) Hit Total Coverage
Test: PostgreSQL 18devel Lines: 6 6 100.0 %
Date: 2025-01-18 04:15:08 Functions: 2 2 100.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /*-------------------------------------------------------------------------
       2             :  *
       3             :  * smgr.h
       4             :  *    storage manager switch public interface declarations.
       5             :  *
       6             :  *
       7             :  * Portions Copyright (c) 1996-2025, PostgreSQL Global Development Group
       8             :  * Portions Copyright (c) 1994, Regents of the University of California
       9             :  *
      10             :  * src/include/storage/smgr.h
      11             :  *
      12             :  *-------------------------------------------------------------------------
      13             :  */
      14             : #ifndef SMGR_H
      15             : #define SMGR_H
      16             : 
      17             : #include "lib/ilist.h"
      18             : #include "storage/block.h"
      19             : #include "storage/relfilelocator.h"
      20             : 
      21             : /*
      22             :  * smgr.c maintains a table of SMgrRelation objects, which are essentially
      23             :  * cached file handles.  An SMgrRelation is created (if not already present)
      24             :  * by smgropen(), and destroyed by smgrdestroy().  Note that neither of these
      25             :  * operations imply I/O, they just create or destroy a hashtable entry.  (But
      26             :  * smgrdestroy() may release associated resources, such as OS-level file
      27             :  * descriptors.)
      28             :  *
      29             :  * An SMgrRelation may be "pinned", to prevent it from being destroyed while
      30             :  * it's in use.  We use this to prevent pointers in relcache to smgr from being
      31             :  * invalidated.  SMgrRelations that are not pinned are deleted at end of
      32             :  * transaction.
      33             :  */
      34             : typedef struct SMgrRelationData
      35             : {
      36             :     /* rlocator is the hashtable lookup key, so it must be first! */
      37             :     RelFileLocatorBackend smgr_rlocator;    /* relation physical identifier */
      38             : 
      39             :     /*
      40             :      * The following fields are reset to InvalidBlockNumber upon a cache flush
      41             :      * event, and hold the last known size for each fork.  This information is
      42             :      * currently only reliable during recovery, since there is no cache
      43             :      * invalidation for fork extension.
      44             :      */
      45             :     BlockNumber smgr_targblock; /* current insertion target block */
      46             :     BlockNumber smgr_cached_nblocks[MAX_FORKNUM + 1];   /* last known size */
      47             : 
      48             :     /* additional public fields may someday exist here */
      49             : 
      50             :     /*
      51             :      * Fields below here are intended to be private to smgr.c and its
      52             :      * submodules.  Do not touch them from elsewhere.
      53             :      */
      54             :     int         smgr_which;     /* storage manager selector */
      55             : 
      56             :     /*
      57             :      * for md.c; per-fork arrays of the number of open segments
      58             :      * (md_num_open_segs) and the segments themselves (md_seg_fds).
      59             :      */
      60             :     int         md_num_open_segs[MAX_FORKNUM + 1];
      61             :     struct _MdfdVec *md_seg_fds[MAX_FORKNUM + 1];
      62             : 
      63             :     /*
      64             :      * Pinning support.  If unpinned (ie. pincount == 0), 'node' is a list
      65             :      * link in list of all unpinned SMgrRelations.
      66             :      */
      67             :     int         pincount;
      68             :     dlist_node  node;
      69             : } SMgrRelationData;
      70             : 
      71             : typedef SMgrRelationData *SMgrRelation;
      72             : 
      73             : #define SmgrIsTemp(smgr) \
      74             :     RelFileLocatorBackendIsTemp((smgr)->smgr_rlocator)
      75             : 
      76             : extern void smgrinit(void);
      77             : extern SMgrRelation smgropen(RelFileLocator rlocator, ProcNumber backend);
      78             : extern bool smgrexists(SMgrRelation reln, ForkNumber forknum);
      79             : extern void smgrpin(SMgrRelation reln);
      80             : extern void smgrunpin(SMgrRelation reln);
      81             : extern void smgrclose(SMgrRelation reln);
      82             : extern void smgrdestroyall(void);
      83             : extern void smgrrelease(SMgrRelation reln);
      84             : extern void smgrreleaseall(void);
      85             : extern void smgrreleaserellocator(RelFileLocatorBackend rlocator);
      86             : extern void smgrcreate(SMgrRelation reln, ForkNumber forknum, bool isRedo);
      87             : extern void smgrdosyncall(SMgrRelation *rels, int nrels);
      88             : extern void smgrdounlinkall(SMgrRelation *rels, int nrels, bool isRedo);
      89             : extern void smgrextend(SMgrRelation reln, ForkNumber forknum,
      90             :                        BlockNumber blocknum, const void *buffer, bool skipFsync);
      91             : extern void smgrzeroextend(SMgrRelation reln, ForkNumber forknum,
      92             :                            BlockNumber blocknum, int nblocks, bool skipFsync);
      93             : extern bool smgrprefetch(SMgrRelation reln, ForkNumber forknum,
      94             :                          BlockNumber blocknum, int nblocks);
      95             : extern uint32 smgrmaxcombine(SMgrRelation reln, ForkNumber forknum,
      96             :                              BlockNumber blocknum);
      97             : extern void smgrreadv(SMgrRelation reln, ForkNumber forknum,
      98             :                       BlockNumber blocknum,
      99             :                       void **buffers, BlockNumber nblocks);
     100             : extern void smgrwritev(SMgrRelation reln, ForkNumber forknum,
     101             :                        BlockNumber blocknum,
     102             :                        const void **buffers, BlockNumber nblocks,
     103             :                        bool skipFsync);
     104             : extern void smgrwriteback(SMgrRelation reln, ForkNumber forknum,
     105             :                           BlockNumber blocknum, BlockNumber nblocks);
     106             : extern BlockNumber smgrnblocks(SMgrRelation reln, ForkNumber forknum);
     107             : extern BlockNumber smgrnblocks_cached(SMgrRelation reln, ForkNumber forknum);
     108             : extern void smgrtruncate(SMgrRelation reln, ForkNumber *forknum, int nforks,
     109             :                          BlockNumber *old_nblocks,
     110             :                          BlockNumber *nblocks);
     111             : extern void smgrimmedsync(SMgrRelation reln, ForkNumber forknum);
     112             : extern void smgrregistersync(SMgrRelation reln, ForkNumber forknum);
     113             : extern void AtEOXact_SMgr(void);
     114             : extern bool ProcessBarrierSmgrRelease(void);
     115             : 
     116             : static inline void
     117        1196 : smgrread(SMgrRelation reln, ForkNumber forknum, BlockNumber blocknum,
     118             :          void *buffer)
     119             : {
     120        1196 :     smgrreadv(reln, forknum, blocknum, &buffer, 1);
     121        1196 : }
     122             : 
     123             : static inline void
     124      963116 : smgrwrite(SMgrRelation reln, ForkNumber forknum, BlockNumber blocknum,
     125             :           const void *buffer, bool skipFsync)
     126             : {
     127      963116 :     smgrwritev(reln, forknum, blocknum, &buffer, 1, skipFsync);
     128      963116 : }
     129             : 
     130             : #endif                          /* SMGR_H */

Generated by: LCOV version 1.14