X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?p=o-du%2Fphy.git;a=blobdiff_plain;f=fapi_5g%2Fsource%2Fapi%2Ffapi2phy%2Fnr5g_fapi_fapi2phy_api.c;h=9a3f1aeb600111421737f115570c99eebcaa5585;hp=fb8984bddcc174fedf1869d1f5d757dd842193d0;hb=2de97529a4c5a1922214ba0e6f0fb84cacbd0bc7;hpb=81a09690b36b3a4e89b4dae34f30933de13f7f90 diff --git a/fapi_5g/source/api/fapi2phy/nr5g_fapi_fapi2phy_api.c b/fapi_5g/source/api/fapi2phy/nr5g_fapi_fapi2phy_api.c index fb8984b..9a3f1ae 100644 --- a/fapi_5g/source/api/fapi2phy/nr5g_fapi_fapi2phy_api.c +++ b/fapi_5g/source/api/fapi2phy/nr5g_fapi_fapi2phy_api.c @@ -31,6 +31,7 @@ #include "nr5g_fapi_log.h" nr5g_fapi_fapi2phy_queue_t fapi2phy_q; +nr5g_fapi_fapi2phy_queue_t fapi2phy_q_urllc; //------------------------------------------------------------------------------ /** @ingroup group_source_api_fapi2phy @@ -50,6 +51,12 @@ p_nr5g_fapi_fapi2phy_queue_t nr5g_fapi_fapi2phy_queue( return &fapi2phy_q; } +p_nr5g_fapi_fapi2phy_queue_t nr5g_fapi_fapi2phy_queue_urllc( + ) +{ + return &fapi2phy_q_urllc; +} + uint8_t nr5g_fapi_get_stats_location( uint8_t msg_type) { @@ -152,6 +159,7 @@ PMAC2PHY_QUEUE_EL nr5g_fapi_fapi2phy_create_api_list_elem( **/ //------------------------------------------------------------------------------ void nr5g_fapi_fapi2phy_add_to_api_list( + bool is_urllc, PMAC2PHY_QUEUE_EL p_list_elem) { p_nr5g_fapi_fapi2phy_queue_t queue = NULL; @@ -160,7 +168,9 @@ void nr5g_fapi_fapi2phy_add_to_api_list( return; } - queue = nr5g_fapi_fapi2phy_queue(); + queue = is_urllc ? nr5g_fapi_fapi2phy_queue_urllc() + : nr5g_fapi_fapi2phy_queue(); + if (queue->p_send_list_head && queue->p_send_list_tail) { queue->p_send_list_tail->pNext = p_list_elem; queue->p_send_list_tail = p_list_elem; @@ -181,17 +191,18 @@ void nr5g_fapi_fapi2phy_add_to_api_list( **/ //------------------------------------------------------------------------------ void nr5g_fapi_fapi2phy_send_api_list( - ) + bool is_urllc) { uint8_t ret = FAILURE; p_nr5g_fapi_fapi2phy_queue_t queue = NULL; - queue = nr5g_fapi_fapi2phy_queue(); + queue = is_urllc ? nr5g_fapi_fapi2phy_queue_urllc() + : nr5g_fapi_fapi2phy_queue(); if (queue->p_send_list_head) { NR5G_FAPI_LOG(TRACE_LOG, ("[NR5G_FAPI][FAPI2PHY] Sending API's to PHY")); - ret = nr5g_fapi_fapi2phy_wls_send(queue->p_send_list_head); + ret = nr5g_fapi_fapi2phy_wls_send(queue->p_send_list_head, is_urllc); if (FAILURE == ret) { NR5G_FAPI_LOG(ERROR_LOG, ("[NR5G_FAPI][FAPI2PHY] Error sending API's to PHY"));