LCOV - code coverage report
Current view: top level - app/fdctl - ready.c (source / functions) Hit Total Coverage
Test: cov.lcov Lines: 0 27 0.0 %
Date: 2025-01-08 12:08:44 Functions: 0 1 0.0 %

          Line data    Source code
       1             : #include "fdctl.h"
       2             : 
       3             : #include "run/run.h"
       4             : 
       5             : #include "../../tango/fd_tango.h"
       6             : 
       7             : void
       8             : ready_cmd_fn( args_t *         args,
       9           0 :               config_t * const config ) {
      10           0 :   (void)args;
      11             : 
      12           0 :   ulong wksp_id = fd_topo_find_wksp( &config->topo, "metric_in" );
      13           0 :   FD_TEST( wksp_id!=ULONG_MAX );
      14             : 
      15           0 :   fd_topo_join_workspace( &config->topo, &config->topo.workspaces[ wksp_id ], FD_SHMEM_JOIN_MODE_READ_ONLY );
      16           0 :   fd_topo_workspace_fill( &config->topo, &config->topo.workspaces[ wksp_id ] );
      17             : 
      18           0 :   for( ulong i=0; i<config->topo.tile_cnt; i++) {
      19           0 :     fd_topo_tile_t * tile = &config->topo.tiles[i];
      20             : 
      21             :     /* Don't wait for agave hosted tiles yet, they will take a
      22             :        long time, and aren't needed to start sending transactions
      23             :        anyway. */
      24           0 :     if( FD_UNLIKELY( tile->is_agave ) ) continue;
      25             : 
      26             :     /* Don't wait for rtpool/stpool tiles, they will not report ready. */
      27           0 :     if( strncmp( tile->name, "rtpool", 7 )==0 ) continue;
      28           0 :     if( strncmp( tile->name, "stpool", 7 )==0 ) continue;
      29             : 
      30           0 :     long start = fd_log_wallclock();
      31           0 :     int printed = 0;
      32           0 :     do {
      33           0 :       ulong status = fd_metrics_tile( tile->metrics )[ FD_METRICS_GAUGE_TILE_STATUS_OFF ];
      34             : 
      35           0 :       if( FD_LIKELY( status==1UL ) ) break;
      36           0 :       else if( FD_UNLIKELY( status ) )
      37           0 :         FD_LOG_ERR(( "status for tile %s:%lu is in bad state %lu", tile->name, tile->kind_id, status ));
      38             : 
      39           0 :       if( FD_UNLIKELY( !printed && (fd_log_wallclock()-start) > 2L*1000*1000*1000L ) ) {
      40           0 :         FD_LOG_NOTICE(( "waiting for tile %s:%lu to be ready", tile->name, tile->kind_id ));
      41           0 :         printed = 1;
      42           0 :       }
      43           0 :     } while(1);
      44           0 :   }
      45             : 
      46           0 :   fd_topo_leave_workspaces( &config->topo );
      47           0 :   FD_LOG_NOTICE(( "all tiles ready" ));
      48           0 : }

Generated by: LCOV version 1.14