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 :