LCOV - code coverage report
Current view: top level - src/backend/utils/misc - pg_rusage.c (source / functions) Coverage Total Hit
Test: PostgreSQL 19devel Lines: 91.7 % 24 22
Test Date: 2026-03-11 22:14:46 Functions: 100.0 % 2 2
Legend: Lines:     hit not hit

            Line data    Source code
       1              : /*-------------------------------------------------------------------------
       2              :  *
       3              :  * pg_rusage.c
       4              :  *    Resource usage measurement support routines.
       5              :  *
       6              :  *
       7              :  * Portions Copyright (c) 1996-2026, PostgreSQL Global Development Group
       8              :  * Portions Copyright (c) 1994, Regents of the University of California
       9              :  *
      10              :  *
      11              :  * IDENTIFICATION
      12              :  *    src/backend/utils/misc/pg_rusage.c
      13              :  *
      14              :  *-------------------------------------------------------------------------
      15              :  */
      16              : #include "postgres.h"
      17              : 
      18              : #include <unistd.h>
      19              : 
      20              : #include "utils/pg_rusage.h"
      21              : 
      22              : 
      23              : /*
      24              :  * Initialize usage snapshot.
      25              :  */
      26              : void
      27       214539 : pg_rusage_init(PGRUsage *ru0)
      28              : {
      29       214539 :     getrusage(RUSAGE_SELF, &ru0->ru);
      30       214539 :     gettimeofday(&ru0->tv, NULL);
      31       214539 : }
      32              : 
      33              : /*
      34              :  * Compute elapsed time since ru0 usage snapshot, and format into
      35              :  * a displayable string.  Result is in a static string, which is
      36              :  * tacky, but no one ever claimed that the Postgres backend is
      37              :  * threadable...
      38              :  */
      39              : const char *
      40       104849 : pg_rusage_show(const PGRUsage *ru0)
      41              : {
      42              :     static char result[100];
      43              :     PGRUsage    ru1;
      44              : 
      45       104849 :     pg_rusage_init(&ru1);
      46              : 
      47       104849 :     if (ru1.tv.tv_usec < ru0->tv.tv_usec)
      48              :     {
      49          724 :         ru1.tv.tv_sec--;
      50          724 :         ru1.tv.tv_usec += 1000000;
      51              :     }
      52       104849 :     if (ru1.ru.ru_stime.tv_usec < ru0->ru.ru_stime.tv_usec)
      53              :     {
      54            0 :         ru1.ru.ru_stime.tv_sec--;
      55            0 :         ru1.ru.ru_stime.tv_usec += 1000000;
      56              :     }
      57       104849 :     if (ru1.ru.ru_utime.tv_usec < ru0->ru.ru_utime.tv_usec)
      58              :     {
      59            1 :         ru1.ru.ru_utime.tv_sec--;
      60            1 :         ru1.ru.ru_utime.tv_usec += 1000000;
      61              :     }
      62              : 
      63       104849 :     snprintf(result, sizeof(result),
      64       104849 :              _("CPU: user: %d.%02d s, system: %d.%02d s, elapsed: %d.%02d s"),
      65       104849 :              (int) (ru1.ru.ru_utime.tv_sec - ru0->ru.ru_utime.tv_sec),
      66       104849 :              (int) (ru1.ru.ru_utime.tv_usec - ru0->ru.ru_utime.tv_usec) / 10000,
      67       104849 :              (int) (ru1.ru.ru_stime.tv_sec - ru0->ru.ru_stime.tv_sec),
      68       104849 :              (int) (ru1.ru.ru_stime.tv_usec - ru0->ru.ru_stime.tv_usec) / 10000,
      69       104849 :              (int) (ru1.tv.tv_sec - ru0->tv.tv_sec),
      70       104849 :              (int) (ru1.tv.tv_usec - ru0->tv.tv_usec) / 10000);
      71              : 
      72       104849 :     return result;
      73              : }
        

Generated by: LCOV version 2.0-1