1 /******************************************************************************
3 * Copyright (c) 2019 Intel.
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
17 *******************************************************************************/
18 #include "nr5g_fapi_framework.h"
19 #include "nr5g_fapi_fapi2phy_wls.h"
20 #include "nr5g_fapi_phy2mac_thread.h"
21 #include "nr5g_fapi_fapi2mac_api.h"
22 #include "nr5g_fapi_fapi2mac_p5_proc.h"
23 #include "nr5g_fapi_fapi2mac_p7_proc.h"
25 //------------------------------------------------------------------------------
26 /** @ingroup nr5g_fapi_source_framework_workers_phy2mac_group
36 //------------------------------------------------------------------------------
37 void *nr5g_fapi_phy2mac_thread_func(
42 PMAC2PHY_QUEUE_EL p_msg_list = NULL;
43 p_nr5g_fapi_phy_ctx_t p_phy_ctx = (p_nr5g_fapi_phy_ctx_t) config;
45 NR5G_FAPI_LOG(INFO_LOG, ("[PHY2MAC] Thread %s launched LWP:%ld on "
46 "Core: %d\n", __func__, pthread_self(),
47 p_phy_ctx->phy2mac_worker_core_id));
49 thread = p_phy_ctx->phy2mac_tid = pthread_self();
51 CPU_SET(p_phy_ctx->phy2mac_worker_core_id, &cpuset);
52 pthread_setaffinity_np(thread, sizeof(cpu_set_t), &cpuset);
55 while (!p_phy_ctx->process_exit) {
56 p_msg_list = nr5g_fapi_fapi2phy_wls_recv();
58 nr5g_fapi_phy2mac_api_recv_handler(config, p_msg_list);
60 nr5g_fapi_fapi2mac_send_api_list();
65 //------------------------------------------------------------------------------
66 /** @ingroup nr5g_fapi_source_framework_workers_mac2phy_group
76 //------------------------------------------------------------------------------
77 void nr5g_fapi_phy2mac_api_recv_handler(
79 PMAC2PHY_QUEUE_EL p_msg_list)
81 PMAC2PHY_QUEUE_EL p_curr_msg;
82 PL1L2MessageHdr p_msg_header = NULL;
84 NR5G_FAPI_LOG(TRACE_LOG, ("[PHY2MAC] %s:", __func__));
86 nr5g_fapi_message_header((p_nr5g_fapi_phy_ctx_t) config);
88 p_curr_msg = (PMAC2PHY_QUEUE_EL) p_msg_list;
90 p_msg_header = (PL1L2MessageHdr) (p_curr_msg + 1);
91 switch (p_msg_header->nMessageType) {
92 /* P5 Vendor Message Processing */
94 case MSG_TYPE_PHY_DL_IQ_SAMPLES:
96 nr5g_fapi_dl_iq_samples_response((p_nr5g_fapi_phy_ctx_t)
97 config, (PADD_REMOVE_BBU_CORES) p_msg_header);
101 case MSG_TYPE_PHY_UL_IQ_SAMPLES:
103 nr5g_fapi_ul_iq_samples_response((p_nr5g_fapi_phy_ctx_t)
104 config, (PADD_REMOVE_BBU_CORES) p_msg_header);
108 case MSG_TYPE_PHY_SHUTDOWN_RESP:
110 nr5g_fapi_shutdown_response((p_nr5g_fapi_phy_ctx_t) config,
111 (PSHUTDOWNRESPONSEStruct) p_msg_header);
115 /* P5 Message Processing */
116 case MSG_TYPE_PHY_CONFIG_RESP:
118 nr5g_fapi_config_response((p_nr5g_fapi_phy_ctx_t) config,
119 (PCONFIGRESPONSEStruct) p_msg_header);
123 case MSG_TYPE_PHY_START_RESP:
125 nr5g_fapi_start_resp((p_nr5g_fapi_phy_ctx_t) config,
126 (PSTARTRESPONSEStruct) p_msg_header);
130 case MSG_TYPE_PHY_STOP_RESP:
132 nr5g_fapi_stop_indication((p_nr5g_fapi_phy_ctx_t) config,
133 (PSTOPRESPONSEStruct) p_msg_header);
137 /* P7 Message Processing */
138 case MSG_TYPE_PHY_RX_ULSCH_IND:
140 nr5g_fapi_rx_data_indication((p_nr5g_fapi_phy_ctx_t) config,
141 (PRXULSCHIndicationStruct) p_msg_header);
145 case MSG_TYPE_PHY_RX_ULSCH_UCI_IND:
151 case MSG_TYPE_PHY_CRC_IND:
153 nr5g_fapi_crc_indication((p_nr5g_fapi_phy_ctx_t) config,
154 (PCRCIndicationStruct) p_msg_header);
158 case MSG_TYPE_PHY_UCI_IND:
160 nr5g_fapi_uci_indication((p_nr5g_fapi_phy_ctx_t) config,
161 (PRXUCIIndicationStruct) p_msg_header);
165 case MSG_TYPE_PHY_RX_RACH_IND:
167 nr5g_fapi_rach_indication((p_nr5g_fapi_phy_ctx_t) config,
168 (PRXRACHIndicationStruct) p_msg_header);
172 case MSG_TYPE_PHY_RX_SRS_IND:
174 nr5g_fapi_srs_indication((p_nr5g_fapi_phy_ctx_t) config,
175 (PRXSRSIndicationStruct) p_msg_header);
179 case MSG_TYPE_PHY_SLOT_IND:
181 nr5g_fapi_slot_indication((p_nr5g_fapi_phy_ctx_t) config,
182 (PSlotIndicationStruct) p_msg_header);
186 case MSG_TYPE_PHY_ERR_IND:
192 printf("%s: Unknown Message type: %x\n", __func__,
193 p_msg_header->nMessageType);
196 p_curr_msg = p_curr_msg->pNext;