LCOV - code coverage report
Current view: top level - src/bin/pg_waldump - hashdesc.c (source / functions) Hit Total Coverage
Test: PostgreSQL 19devel Lines: 47 107 43.9 %
Date: 2025-10-10 18:17:38 Functions: 2 2 100.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /*-------------------------------------------------------------------------
       2             :  *
       3             :  * hashdesc.c
       4             :  *    rmgr descriptor routines for access/hash/hash.c
       5             :  *
       6             :  * Portions Copyright (c) 1996-2025, PostgreSQL Global Development Group
       7             :  * Portions Copyright (c) 1994, Regents of the University of California
       8             :  *
       9             :  *
      10             :  * IDENTIFICATION
      11             :  *    src/backend/access/rmgrdesc/hashdesc.c
      12             :  *
      13             :  *-------------------------------------------------------------------------
      14             :  */
      15             : #include "postgres.h"
      16             : 
      17             : #include "access/hash_xlog.h"
      18             : 
      19             : void
      20         108 : hash_desc(StringInfo buf, XLogReaderState *record)
      21             : {
      22         108 :     char       *rec = XLogRecGetData(record);
      23         108 :     uint8       info = XLogRecGetInfo(record) & ~XLR_INFO_MASK;
      24             : 
      25         108 :     switch (info)
      26             :     {
      27          24 :         case XLOG_HASH_INIT_META_PAGE:
      28             :             {
      29          24 :                 xl_hash_init_meta_page *xlrec = (xl_hash_init_meta_page *) rec;
      30             : 
      31          24 :                 appendStringInfo(buf, "num_tuples %g, procid %u, fillfactor %d",
      32             :                                  xlrec->num_tuples,
      33             :                                  xlrec->procid,
      34          24 :                                  xlrec->ffactor);
      35          24 :                 break;
      36             :             }
      37          24 :         case XLOG_HASH_INIT_BITMAP_PAGE:
      38             :             {
      39          24 :                 xl_hash_init_bitmap_page *xlrec = (xl_hash_init_bitmap_page *) rec;
      40             : 
      41          24 :                 appendStringInfo(buf, "bmsize %d", xlrec->bmsize);
      42          24 :                 break;
      43             :             }
      44          36 :         case XLOG_HASH_INSERT:
      45             :             {
      46          36 :                 xl_hash_insert *xlrec = (xl_hash_insert *) rec;
      47             : 
      48          36 :                 appendStringInfo(buf, "off %u", xlrec->offnum);
      49          36 :                 break;
      50             :             }
      51           0 :         case XLOG_HASH_ADD_OVFL_PAGE:
      52             :             {
      53           0 :                 xl_hash_add_ovfl_page *xlrec = (xl_hash_add_ovfl_page *) rec;
      54             : 
      55           0 :                 appendStringInfo(buf, "bmsize %d, bmpage_found %c",
      56           0 :                                  xlrec->bmsize, (xlrec->bmpage_found) ? 'T' : 'F');
      57           0 :                 break;
      58             :             }
      59           0 :         case XLOG_HASH_SPLIT_ALLOCATE_PAGE:
      60             :             {
      61           0 :                 xl_hash_split_allocate_page *xlrec = (xl_hash_split_allocate_page *) rec;
      62             : 
      63           0 :                 appendStringInfo(buf, "new_bucket %u, old_bucket_flag %u, new_bucket_flag %u, meta_page_masks_updated %c, issplitpoint_changed %c",
      64             :                                  xlrec->new_bucket,
      65           0 :                                  xlrec->old_bucket_flag,
      66           0 :                                  xlrec->new_bucket_flag,
      67           0 :                                  (xlrec->flags & XLH_SPLIT_META_UPDATE_MASKS) ? 'T' : 'F',
      68           0 :                                  (xlrec->flags & XLH_SPLIT_META_UPDATE_SPLITPOINT) ? 'T' : 'F');
      69           0 :                 break;
      70             :             }
      71           0 :         case XLOG_HASH_SPLIT_COMPLETE:
      72             :             {
      73           0 :                 xl_hash_split_complete *xlrec = (xl_hash_split_complete *) rec;
      74             : 
      75           0 :                 appendStringInfo(buf, "old_bucket_flag %u, new_bucket_flag %u",
      76           0 :                                  xlrec->old_bucket_flag, xlrec->new_bucket_flag);
      77           0 :                 break;
      78             :             }
      79           0 :         case XLOG_HASH_MOVE_PAGE_CONTENTS:
      80             :             {
      81           0 :                 xl_hash_move_page_contents *xlrec = (xl_hash_move_page_contents *) rec;
      82             : 
      83           0 :                 appendStringInfo(buf, "ntups %d, is_primary %c",
      84           0 :                                  xlrec->ntups,
      85           0 :                                  xlrec->is_prim_bucket_same_wrt ? 'T' : 'F');
      86           0 :                 break;
      87             :             }
      88           0 :         case XLOG_HASH_SQUEEZE_PAGE:
      89             :             {
      90           0 :                 xl_hash_squeeze_page *xlrec = (xl_hash_squeeze_page *) rec;
      91             : 
      92           0 :                 appendStringInfo(buf, "prevblkno %u, nextblkno %u, ntups %d, is_primary %c, is_previous %c",
      93             :                                  xlrec->prevblkno,
      94             :                                  xlrec->nextblkno,
      95           0 :                                  xlrec->ntups,
      96           0 :                                  xlrec->is_prim_bucket_same_wrt ? 'T' : 'F',
      97           0 :                                  xlrec->is_prev_bucket_same_wrt ? 'T' : 'F');
      98           0 :                 break;
      99             :             }
     100          12 :         case XLOG_HASH_DELETE:
     101             :             {
     102          12 :                 xl_hash_delete *xlrec = (xl_hash_delete *) rec;
     103             : 
     104          24 :                 appendStringInfo(buf, "clear_dead_marking %c, is_primary %c",
     105          12 :                                  xlrec->clear_dead_marking ? 'T' : 'F',
     106          12 :                                  xlrec->is_primary_bucket_page ? 'T' : 'F');
     107          12 :                 break;
     108             :             }
     109          12 :         case XLOG_HASH_UPDATE_META_PAGE:
     110             :             {
     111          12 :                 xl_hash_update_meta_page *xlrec = (xl_hash_update_meta_page *) rec;
     112             : 
     113          12 :                 appendStringInfo(buf, "ntuples %g",
     114             :                                  xlrec->ntuples);
     115          12 :                 break;
     116             :             }
     117           0 :         case XLOG_HASH_VACUUM_ONE_PAGE:
     118             :             {
     119           0 :                 xl_hash_vacuum_one_page *xlrec = (xl_hash_vacuum_one_page *) rec;
     120             : 
     121           0 :                 appendStringInfo(buf, "ntuples %d, snapshotConflictHorizon %u, isCatalogRel %c",
     122           0 :                                  xlrec->ntuples,
     123             :                                  xlrec->snapshotConflictHorizon,
     124           0 :                                  xlrec->isCatalogRel ? 'T' : 'F');
     125           0 :                 break;
     126             :             }
     127             :     }
     128         108 : }
     129             : 
     130             : const char *
     131         118 : hash_identify(uint8 info)
     132             : {
     133         118 :     const char *id = NULL;
     134             : 
     135         118 :     switch (info & ~XLR_INFO_MASK)
     136             :     {
     137          26 :         case XLOG_HASH_INIT_META_PAGE:
     138          26 :             id = "INIT_META_PAGE";
     139          26 :             break;
     140          26 :         case XLOG_HASH_INIT_BITMAP_PAGE:
     141          26 :             id = "INIT_BITMAP_PAGE";
     142          26 :             break;
     143          38 :         case XLOG_HASH_INSERT:
     144          38 :             id = "INSERT";
     145          38 :             break;
     146           0 :         case XLOG_HASH_ADD_OVFL_PAGE:
     147           0 :             id = "ADD_OVFL_PAGE";
     148           0 :             break;
     149           0 :         case XLOG_HASH_SPLIT_ALLOCATE_PAGE:
     150           0 :             id = "SPLIT_ALLOCATE_PAGE";
     151           0 :             break;
     152           0 :         case XLOG_HASH_SPLIT_PAGE:
     153           0 :             id = "SPLIT_PAGE";
     154           0 :             break;
     155           0 :         case XLOG_HASH_SPLIT_COMPLETE:
     156           0 :             id = "SPLIT_COMPLETE";
     157           0 :             break;
     158           0 :         case XLOG_HASH_MOVE_PAGE_CONTENTS:
     159           0 :             id = "MOVE_PAGE_CONTENTS";
     160           0 :             break;
     161           0 :         case XLOG_HASH_SQUEEZE_PAGE:
     162           0 :             id = "SQUEEZE_PAGE";
     163           0 :             break;
     164          14 :         case XLOG_HASH_DELETE:
     165          14 :             id = "DELETE";
     166          14 :             break;
     167           0 :         case XLOG_HASH_SPLIT_CLEANUP:
     168           0 :             id = "SPLIT_CLEANUP";
     169           0 :             break;
     170          14 :         case XLOG_HASH_UPDATE_META_PAGE:
     171          14 :             id = "UPDATE_META_PAGE";
     172          14 :             break;
     173           0 :         case XLOG_HASH_VACUUM_ONE_PAGE:
     174           0 :             id = "VACUUM_ONE_PAGE";
     175             :     }
     176             : 
     177         118 :     return id;
     178             : }

Generated by: LCOV version 1.16