LCOV - code coverage report
Current view: top level - waltz/quic - fd_quic_pkt_meta.c (source / functions) Hit Total Coverage
Test: cov.lcov Lines: 54 54 100.0 %
Date: 2025-01-08 12:08:44 Functions: 7 7 100.0 %

          Line data    Source code
       1             : #include "fd_quic_pkt_meta.h"
       2             : 
       3             : /* initialize pool with existing array of pkt_meta */
       4             : void
       5             : fd_quic_pkt_meta_pool_init( fd_quic_pkt_meta_pool_t * pool,
       6             :                             fd_quic_pkt_meta_t *      pkt_meta_array,
       7      314376 :                             ulong                     pkt_meta_array_sz ) {
       8             :   /* initialize all to zeros */
       9      314376 :   fd_memset( pool, 0, sizeof( *pool ) );
      10             : 
      11             :   /* free list */
      12      314376 :   fd_quic_pkt_meta_list_t * free = &pool->free;
      13             : 
      14             :   /* initialize free list of packet metadata */
      15    13839126 :   for( ulong j = 0; j < pkt_meta_array_sz; ++j ) {
      16    13524750 :     fd_quic_pkt_meta_push_back( free, &pkt_meta_array[j] );
      17    13524750 :   }
      18             : 
      19      314376 : }
      20             : 
      21             : 
      22             : /* pop from front of list */
      23             : fd_quic_pkt_meta_t *
      24    14363099 : fd_quic_pkt_meta_pop_front( fd_quic_pkt_meta_list_t * list ) {
      25    14363099 :   fd_quic_pkt_meta_t * front = list->head;
      26    14363099 :   if( front ) {
      27    14363099 :     list->head = front->next;
      28    14363099 :   }
      29    14363099 :   return front;
      30    14363099 : }
      31             : 
      32             : 
      33             : /* push onto front of list */
      34             : void
      35             : fd_quic_pkt_meta_push_front( fd_quic_pkt_meta_list_t * list,
      36    14344917 :                              fd_quic_pkt_meta_t *      pkt_meta ) {
      37    14344917 :   pkt_meta->next = list->head;
      38    14344917 :   list->head     = pkt_meta;
      39    14344917 : }
      40             : 
      41             : 
      42             : /* push onto back of list */
      43             : void
      44             : fd_quic_pkt_meta_push_back( fd_quic_pkt_meta_list_t * list,
      45    26294028 :                             fd_quic_pkt_meta_t *      pkt_meta ) {
      46    26294028 :   fd_quic_pkt_meta_t * tail = list->tail;
      47    26294028 :   if( tail ) {
      48    24355750 :     tail->next = pkt_meta;
      49    24355750 :     list->tail = pkt_meta;
      50    24355750 :   } else {
      51     1938278 :     list->head = list->tail = pkt_meta;
      52     1938278 :   }
      53             : 
      54    26294028 :   pkt_meta->next = NULL;
      55    26294028 : }
      56             : 
      57             : /* remove from list
      58             :    requires the prior element */
      59             : void
      60             : fd_quic_pkt_meta_remove( fd_quic_pkt_meta_list_t * list,
      61             :                          fd_quic_pkt_meta_t *      pkt_meta_prior,
      62    12751096 :                          fd_quic_pkt_meta_t *      pkt_meta ) {
      63    12751096 :   fd_quic_pkt_meta_t * pkt_meta_next = pkt_meta->next;
      64             : 
      65    12751096 :   if( pkt_meta_prior == NULL ) {
      66    12751093 :     if( pkt_meta_next == NULL ) {
      67             :       /* at tail... then head = tail = NULL */
      68     1611797 :       list->head = list->tail = NULL;
      69    11139296 :     } else {
      70             :       /* at head... move it to next */
      71    11139296 :       list->head = pkt_meta_next;
      72    11139296 :     }
      73    12751093 :   } else {
      74           3 :     if( pkt_meta_next == NULL ) {
      75             :       /* we're removing the last, so move tail */
      76           3 :       list->tail = pkt_meta_prior;
      77           3 :     }
      78             : 
      79             :     /* not head, make pkt_meta_prior point to next */
      80           3 :     pkt_meta_prior->next = pkt_meta_next;
      81           3 :   }
      82             : 
      83    12751096 :   pkt_meta->next = NULL;
      84    12751096 : }
      85             : 
      86             : 
      87             : /* allocate a pkt_meta
      88             :    obtains a free pkt_meta from the free list, and returns it
      89             :    returns NULL if none is available */
      90             : fd_quic_pkt_meta_t *
      91    14363099 : fd_quic_pkt_meta_allocate( fd_quic_pkt_meta_pool_t * pool ) {
      92    14363099 :   fd_quic_pkt_meta_t * pkt_meta = fd_quic_pkt_meta_pop_front( &pool->free );
      93    14363099 :   if( FD_LIKELY( pkt_meta ) ) {
      94    14363099 :     fd_memset( pkt_meta, 0, sizeof( *pkt_meta ) );
      95    14363099 :   }
      96    14363099 :   return pkt_meta;
      97    14363099 : }
      98             : 
      99             : 
     100             : /* free a pkt_meta
     101             :    returns a pkt_meta to the free list, ready to be allocated again */
     102             : void
     103    14344917 : fd_quic_pkt_meta_deallocate( fd_quic_pkt_meta_pool_t * pool, fd_quic_pkt_meta_t * pkt_meta ) {
     104             :   /* pushing to the front should help cache usage */
     105    14344917 :   fd_quic_pkt_meta_push_front( &pool->free, pkt_meta );
     106    14344917 : }
     107             : 
     108             : 

Generated by: LCOV version 1.14