LCOV - code coverage report
Current view: top level - src/backend/utils/misc - pg_rusage.c (source / functions) Hit Total Coverage
Test: PostgreSQL 18devel Lines: 22 24 91.7 %
Date: 2025-01-18 03:14:54 Functions: 2 2 100.0 %
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-2025, 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      197326 : pg_rusage_init(PGRUsage *ru0)
      28             : {
      29      197326 :     getrusage(RUSAGE_SELF, &ru0->ru);
      30      197326 :     gettimeofday(&ru0->tv, NULL);
      31      197326 : }
      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       94230 : pg_rusage_show(const PGRUsage *ru0)
      41             : {
      42             :     static char result[100];
      43             :     PGRUsage    ru1;
      44             : 
      45       94230 :     pg_rusage_init(&ru1);
      46             : 
      47       94230 :     if (ru1.tv.tv_usec < ru0->tv.tv_usec)
      48             :     {
      49         342 :         ru1.tv.tv_sec--;
      50         342 :         ru1.tv.tv_usec += 1000000;
      51             :     }
      52       94230 :     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       94230 :     if (ru1.ru.ru_utime.tv_usec < ru0->ru.ru_utime.tv_usec)
      58             :     {
      59           2 :         ru1.ru.ru_utime.tv_sec--;
      60           2 :         ru1.ru.ru_utime.tv_usec += 1000000;
      61             :     }
      62             : 
      63       94230 :     snprintf(result, sizeof(result),
      64       94230 :              _("CPU: user: %d.%02d s, system: %d.%02d s, elapsed: %d.%02d s"),
      65       94230 :              (int) (ru1.ru.ru_utime.tv_sec - ru0->ru.ru_utime.tv_sec),
      66       94230 :              (int) (ru1.ru.ru_utime.tv_usec - ru0->ru.ru_utime.tv_usec) / 10000,
      67       94230 :              (int) (ru1.ru.ru_stime.tv_sec - ru0->ru.ru_stime.tv_sec),
      68       94230 :              (int) (ru1.ru.ru_stime.tv_usec - ru0->ru.ru_stime.tv_usec) / 10000,
      69       94230 :              (int) (ru1.tv.tv_sec - ru0->tv.tv_sec),
      70       94230 :              (int) (ru1.tv.tv_usec - ru0->tv.tv_usec) / 10000);
      71             : 
      72       94230 :     return result;
      73             : }

Generated by: LCOV version 1.14