O-RAN E Maintenance Release contribution for ODULOW
[o-du/phy.git] / fhi_lib / test / test_xran / u_plane_performance.cc
index 554b00a..757a9b9 100644 (file)
-/******************************************************************************\r
-*\r
-*   Copyright (c) 2019 Intel.\r
-*\r
-*   Licensed under the Apache License, Version 2.0 (the "License");\r
-*   you may not use this file except in compliance with the License.\r
-*   You may obtain a copy of the License at\r
-*\r
-*       http://www.apache.org/licenses/LICENSE-2.0\r
-*\r
-*   Unless required by applicable law or agreed to in writing, software\r
-*   distributed under the License is distributed on an "AS IS" BASIS,\r
-*   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
-*   See the License for the specific language governing permissions and\r
-*   limitations under the License.\r
-*\r
-*******************************************************************************/\r
-\r
-\r
-#include "common.hpp"\r
-\r
-#include "xran_common.h"\r
-#include "xran_fh_o_du.h"\r
-#include "ethernet.h"\r
-\r
-#include <stdint.h>\r
-\r
-const std::string module_name = "u-plane";\r
-\r
-class U_planePerf : public KernelTests\r
-{\r
-\r
-protected:\r
-    int32_t request;\r
-    int32_t response;\r
-\r
-    struct rte_mbuf *test_buffer;\r
-    char * iq_offset;\r
-    struct rte_mempool *test_eth_mbuf_pool;\r
-\r
-    void SetUp() override\r
-    {\r
-        /* Parameters stored in the functional section will be used. GTest will call\r
-           TEST_P (including SetUp and TearDown) for each case in the section. */\r
-        init_test("u_plane_performace");\r
-        test_eth_mbuf_pool = rte_pktmbuf_pool_create("mempool", NUM_MBUFS,\r
-                MBUF_CACHE, 0, MBUF_POOL_ELEMENT, rte_socket_id());\r
-\r
-        /* buffer size defined as the maximum size of all inputs/outputs in BYTE */\r
-        const int buffer_size = 9600;\r
-        test_buffer = (struct rte_mbuf*)rte_pktmbuf_alloc(test_eth_mbuf_pool);\r
-\r
-        iq_offset = rte_pktmbuf_mtod(test_buffer, char * );\r
-        iq_offset = iq_offset + sizeof(struct ether_hdr) +\r
-                                    sizeof (struct xran_ecpri_hdr) +\r
-                                    sizeof (struct radio_app_common_hdr) +\r
-                                    sizeof(struct data_section_hdr);\r
-    }\r
-\r
-    /* It's called after an execution of the each test case.*/\r
-    void TearDown() override\r
-    {\r
-        rte_pktmbuf_free(test_buffer);\r
-    }\r
-\r
-    void fucntional_dl(F function, int32_t* request, int32_t* response)\r
-    {\r
-        enum xran_pkt_dir direction =  XRAN_DIR_DL;\r
-        uint16_t section_id = 0;\r
-        enum xran_input_byte_order iq_buf_byte_order = XRAN_CPU_LE_BYTE_ORDER;\r
-        uint8_t frame_id = 0;\r
-        uint8_t subframe_id  = 0;\r
-        uint8_t slot_id = 0;\r
-        uint8_t symbol_no = 0;\r
-        int prb_start = 0;\r
-        int prb_num = 66;\r
-        uint8_t CC_ID = 0;\r
-        uint8_t RU_Port_ID = 0;\r
-        uint8_t seq_id =0;\r
-        uint32_t do_copy = 0;\r
-\r
-        int32_t prep_bytes;\r
-\r
-        prep_bytes = prepare_symbol_ex(direction,\r
-                                    section_id,\r
-                                    test_buffer,\r
-                                    (struct rb_map *)iq_offset,\r
-                                    iq_buf_byte_order,\r
-                                    frame_id,\r
-                                    subframe_id,\r
-                                    slot_id,\r
-                                    symbol_no,\r
-                                    prb_start,\r
-                                    prb_num,\r
-                                    CC_ID,\r
-                                    RU_Port_ID,\r
-                                    seq_id,\r
-                                    do_copy);\r
-\r
-        //ASSERT_EQ(prep_bytes, 3168);\r
-    }\r
-};\r
-\r
-TEST_P(U_planePerf, Test_DL)\r
-{\r
-    performance("C", module_name, fucntional_dl, &request, &response);\r
-}\r
-\r
-INSTANTIATE_TEST_CASE_P(UnitTest, U_planePerf,\r
-                        testing::ValuesIn(get_sequence(U_planePerf::get_number_of_cases("u_plane_performance"))));\r
-\r
-\r
+/******************************************************************************
+*
+*   Copyright (c) 2020 Intel.
+*
+*   Licensed under the Apache License, Version 2.0 (the "License");
+*   you may not use this file except in compliance with the License.
+*   You may obtain a copy of the License at
+*
+*       http://www.apache.org/licenses/LICENSE-2.0
+*
+*   Unless required by applicable law or agreed to in writing, software
+*   distributed under the License is distributed on an "AS IS" BASIS,
+*   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+*   See the License for the specific language governing permissions and
+*   limitations under the License.
+*
+*******************************************************************************/
+
+
+#include "common.hpp"
+
+#include "xran_common.h"
+#include "xran_up_api.h"
+#include "xran_fh_o_du.h"
+#include "ethernet.h"
+
+#include <stdint.h>
+
+const std::string module_name = "U-Plane";
+
+    /*union xran_test {
+               struct {
+            struct xran_cp_radioapp_common_header cmnhdr;
+            struct xran_radioapp_udComp_header udComp;
+            uint8_t     reserved;
+               }field;
+               struct {
+                       uint32_t     data_one;
+                       uint32_t     data_two;
+               }all_data;
+    };*/
+    void fucntional_dl(struct rte_mbuf *test_buffer, char * iq_offset)
+    {
+        enum xran_pkt_dir direction =  XRAN_DIR_DL;
+        uint16_t section_id = 7;
+        enum xran_input_byte_order iq_buf_byte_order = XRAN_CPU_LE_BYTE_ORDER;
+        uint8_t frame_id = 99;
+        uint8_t subframe_id  = 9;
+        uint8_t slot_id = 10;
+        uint8_t symbol_no = 7;
+        int prb_start = 0;
+        int prb_num = 66;
+        uint8_t CC_ID = 0;
+        uint8_t RU_Port_ID = 0;
+        uint8_t seq_id =0;
+        uint32_t do_copy = 0;
+        uint8_t compMeth = 0;
+        enum xran_comp_hdr_type staticEn = XRAN_COMP_HDR_TYPE_DYNAMIC;
+        uint8_t iqWidth =  16;
+
+        int32_t prep_bytes;
+               
+        prep_bytes = prepare_symbol_ex(direction,
+                                section_id,
+                                test_buffer,
+                                (uint8_t *)iq_offset,
+                                compMeth,
+                                iqWidth,
+                                iq_buf_byte_order,
+                                frame_id,
+                                subframe_id,
+                                slot_id,
+                                symbol_no,
+                                prb_start,
+                                prb_num,
+                                CC_ID,
+                                RU_Port_ID,
+                                seq_id,
+                                do_copy,
+                                staticEn);
+               
+               /*union xran_cp_radioapp_section_ext11 *ext11 = NULL;
+               struct xran_sectionext11_info *params = NULL;
+               int i;
+               ext11 = (union xran_cp_radioapp_section_ext11 *)(iq_offset);
+               params = (struct xran_sectionext11_info *)(iq_offset+100);
+               
+               params->RAD = 1;
+               params->disableBFWs = 1;
+               params->numBundPrb = 1;
+               params->bfwCompMeth = 2;
+               
+        for(i = 0; i< 10000; i++)
+               {
+                       ext11->data_field.data_field1 = (XRAN_CP_SECTIONEXTCMD_11 << 24) | (params->RAD << 7) | (params->disableBFWs << 8);
+                       //ext11->data_field.data_field1 = (XRAN_CP_SECTIONEXTCMD_11 << 24)'
+            //ext11->all_bits.RAD          = params->RAD;
+            //ext11->all_bits.disableBFWs  = params->disableBFWs;
+                       ext11->data_field.data_field2 = (params->bfwCompMeth << 4) | params->numBundPrb;
+            //ext11->all_bits.numBundPrb   = params->numBundPrb;
+            //ext11->all_bits.bfwCompMeth  = params->bfwCompMeth;
+                       
+               }*/
+               //printf("ext11->data_field.data_field1 is %d\n", ext11->data_field.data_field1);
+        //ASSERT_EQ(prep_bytes, 3168);
+    }    
+class U_planePerf : public KernelTests
+{
+
+protected:
+    int32_t request;
+    int32_t response;
+
+    struct rte_mbuf *test_buffer;
+    char * iq_offset;
+
+    void SetUp() override
+    {
+        /* Parameters stored in the functional section will be used. GTest will call
+           TEST_P (including SetUp and TearDown) for each case in the section. */
+        init_test("u_plane_performace");
+        test_buffer = (struct rte_mbuf*)rte_pktmbuf_alloc(_eth_mbuf_pool);
+
+        /* buffer size defined as the maximum size of all inputs/outputs in BYTE */
+        if(test_buffer == NULL) {
+            std::cout << __func__ << ":" << __LINE__ << " Failed to allocatte a packet buffer!" << std::endl;
+            return;
+        }
+        iq_offset = rte_pktmbuf_mtod(test_buffer, char * );
+        iq_offset = iq_offset + sizeof(struct rte_ether_hdr) +
+                                    sizeof (struct xran_ecpri_hdr) +
+                                    sizeof (struct radio_app_common_hdr) +
+                                    sizeof(struct data_section_hdr);
+    }
+
+    /* It's called after an execution of the each test case.*/
+    void TearDown() override
+    {
+        rte_pktmbuf_free(test_buffer);
+    }
+
+
+};
+
+TEST_P(U_planePerf, Perf)
+{
+    performance("C", module_name, &fucntional_dl, test_buffer, iq_offset);
+}
+
+INSTANTIATE_TEST_CASE_P(UnitTest, U_planePerf,
+                        testing::ValuesIn(get_sequence(U_planePerf::get_number_of_cases("u_plane_performance"))));
+
+