diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/plugins/unittest/session_test.c | 105 | ||||
-rw-r--r-- | src/svm/test_svm_message_queue.c | 177 |
2 files changed, 101 insertions, 181 deletions
diff --git a/src/plugins/unittest/session_test.c b/src/plugins/unittest/session_test.c index 948ea62e798..e54c8a6cd86 100644 --- a/src/plugins/unittest/session_test.c +++ b/src/plugins/unittest/session_test.c @@ -1736,7 +1736,7 @@ wait_for_event (svm_msg_q_t * mq, int fd, int epfd, u8 use_eventfd) } static int -session_test_mq (vlib_main_t * vm, unformat_input_t * input) +session_test_mq_speed (vlib_main_t * vm, unformat_input_t * input) { int error, __clib_unused verbose, use_eventfd = 0; u64 i, n_test_msgs = 1 << 10, *counter; @@ -1868,6 +1868,99 @@ session_test_mq (vlib_main_t * vm, unformat_input_t * input) return 0; } +static int +session_test_mq_basic (vlib_main_t * vm, unformat_input_t * input) +{ + svm_msg_q_cfg_t _cfg, *cfg = &_cfg; + svm_msg_q_msg_t msg1, msg2, msg[12]; + int __clib_unused verbose, i, rv; + svm_msg_q_t *mq; + + while (unformat_check_input (input) != UNFORMAT_END_OF_INPUT) + { + if (unformat (input, "verbose")) + verbose = 1; + else + { + vlib_cli_output (vm, "parse error: '%U'", format_unformat_error, + input); + return -1; + } + } + + svm_msg_q_ring_cfg_t rc[2] = { {8, 8, 0} + , {8, 16, 0} + }; + cfg->consumer_pid = ~0; + cfg->n_rings = 2; + cfg->q_nitems = 16; + cfg->ring_cfgs = rc; + + mq = svm_msg_q_alloc (cfg); + SESSION_TEST (mq != 0, "svm_msg_q_alloc"); + SESSION_TEST (vec_len (mq->rings) == 2, "ring allocation"); + + msg1 = svm_msg_q_alloc_msg (mq, 8); + rv = (mq->rings[0].cursize != 1 + || msg1.ring_index != 0 || msg1.elt_index != 0); + SESSION_TEST (rv == 0, "msg alloc1"); + + msg2 = svm_msg_q_alloc_msg (mq, 15); + rv = (mq->rings[1].cursize != 1 + || msg2.ring_index != 1 || msg2.elt_index != 0); + SESSION_TEST (rv == 0, "msg alloc2"); + + svm_msg_q_free_msg (mq, &msg1); + SESSION_TEST (mq->rings[0].cursize == 0, "free msg"); + + for (i = 0; i < 12; i++) + { + msg[i] = svm_msg_q_alloc_msg (mq, 7); + *(u32 *) svm_msg_q_msg_data (mq, &msg[i]) = i; + } + + rv = (mq->rings[0].cursize != 8 || mq->rings[1].cursize != 5); + SESSION_TEST (rv == 0, "msg alloc3"); + + *(u32 *) svm_msg_q_msg_data (mq, &msg2) = 123; + svm_msg_q_add (mq, &msg2, SVM_Q_NOWAIT); + for (i = 0; i < 12; i++) + svm_msg_q_add (mq, &msg[i], SVM_Q_NOWAIT); + + rv = svm_msg_q_sub (mq, &msg2, SVM_Q_NOWAIT, 0); + SESSION_TEST (rv == 0, "dequeue1"); + + SESSION_TEST (msg2.ring_index == 1 && msg2.elt_index == 0, + "dequeue1 result"); + rv = (*(u32 *) svm_msg_q_msg_data (mq, &msg2) == 123); + SESSION_TEST (rv, "dequeue 1 data"); + + svm_msg_q_free_msg (mq, &msg2); + + for (i = 0; i < 12; i++) + { + if (svm_msg_q_sub (mq, &msg[i], SVM_Q_NOWAIT, 0)) + SESSION_TEST (0, "dequeue2"); + if (i < 8) + { + if (msg[i].ring_index != 0 || msg[i].elt_index != (i + 1) % 8) + SESSION_TEST (0, "dequeue2 result2"); + } + else + { + if (msg[i].ring_index != 1 || msg[i].elt_index != (i - 8) + 1) + SESSION_TEST (0, "dequeue2 result3"); + } + if (*(u32 *) svm_msg_q_msg_data (mq, &msg[i]) != i) + SESSION_TEST (0, "dequeue2 wrong data"); + svm_msg_q_free_msg (mq, &msg[i]); + } + rv = (mq->rings[0].cursize == 0 && mq->rings[1].cursize == 0); + SESSION_TEST (rv, "post dequeue"); + + return 0; +} + static clib_error_t * session_test (vlib_main_t * vm, unformat_input_t * input, vlib_cli_command_t * cmd_arg) @@ -1890,8 +1983,10 @@ session_test (vlib_main_t * vm, res = session_test_proxy (vm, input); else if (unformat (input, "endpt-cfg")) res = session_test_endpoint_cfg (vm, input); - else if (unformat (input, "mq")) - res = session_test_mq (vm, input); + else if (unformat (input, "mq-speed")) + res = session_test_mq_speed (vm, input); + else if (unformat (input, "mq-basic")) + res = session_test_mq_basic (vm, input); else if (unformat (input, "all")) { if ((res = session_test_basic (vm, input))) @@ -1906,7 +2001,9 @@ session_test (vlib_main_t * vm, goto done; if ((res = session_test_endpoint_cfg (vm, input))) goto done; - if ((res = session_test_mq (vm, input))) + if ((res = session_test_mq_speed (vm, input))) + goto done; + if ((res = session_test_mq_basic (vm, input))) goto done; } else diff --git a/src/svm/test_svm_message_queue.c b/src/svm/test_svm_message_queue.c deleted file mode 100644 index 84719e6db82..00000000000 --- a/src/svm/test_svm_message_queue.c +++ /dev/null @@ -1,177 +0,0 @@ -/* - * Copyright (c) 2018-2019 Cisco and/or its affiliates. - * 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 <svm/ssvm.h> -#include <svm/message_queue.h> - -#define test1_error(_fmt, _args...) \ -{ \ - ssvm_pop_heap (oldheap); \ - error = clib_error_return (0, _fmt, ##_args); \ - goto done; \ -} - -clib_error_t * -test1 (int verbose) -{ - ssvm_private_t _ssvm, *ssvm = &_ssvm; - svm_msg_q_cfg_t _cfg, *cfg = &_cfg; - svm_msg_q_msg_t msg1, msg2, msg[12]; - ssvm_shared_header_t *sh; - clib_error_t *error = 0; - svm_msg_q_t *mq; - void *oldheap; - int i; - - clib_memset (ssvm, 0, sizeof (*ssvm)); - - ssvm->ssvm_size = 1 << 20; - ssvm->i_am_master = 1; - ssvm->my_pid = getpid (); - ssvm->name = format (0, "%s%c", "test", 0); - ssvm->requested_va = 0; - - if (ssvm_master_init (ssvm, SSVM_SEGMENT_SHM)) - return clib_error_return (0, "failed: segment allocation"); - sh = ssvm->sh; - - svm_msg_q_ring_cfg_t rc[2]= {{8, 8, 0}, {8, 16, 0}}; - cfg->consumer_pid = ~0; - cfg->n_rings = 2; - cfg->q_nitems = 16; - cfg->ring_cfgs = rc; - - oldheap = ssvm_push_heap (sh); - mq = svm_msg_q_alloc (cfg); - if (!mq) - test1_error ("failed: alloc"); - - if (vec_len (mq->rings) != 2) - test1_error ("failed: ring allocation"); - - msg1 = svm_msg_q_alloc_msg (mq, 8); - if (mq->rings[0].cursize != 1 - || msg1.ring_index != 0 - || msg1.elt_index != 0) - test1_error ("failed: msg alloc1"); - - msg2 = svm_msg_q_alloc_msg (mq, 15); - if (mq->rings[1].cursize != 1 - || msg2.ring_index != 1 - || msg2.elt_index != 0) - test1_error ("failed: msg alloc2"); - - svm_msg_q_free_msg (mq, &msg1); - if (mq->rings[0].cursize != 0) - test1_error("failed: free msg"); - - for (i = 0; i < 12; i++) - { - msg[i] = svm_msg_q_alloc_msg (mq, 7); - *(u32 *)svm_msg_q_msg_data (mq, &msg[i]) = i; - } - - if (mq->rings[0].cursize != 8 - || mq->rings[1].cursize != 5) - test1_error ("failed: msg alloc3"); - - *(u32 *)svm_msg_q_msg_data (mq, &msg2) = 123; - svm_msg_q_add (mq, &msg2, SVM_Q_NOWAIT); - for (i = 0; i < 12; i++) - svm_msg_q_add (mq, &msg[i], SVM_Q_NOWAIT); - - if (svm_msg_q_sub (mq, &msg2, SVM_Q_NOWAIT, 0)) - test1_error ("failed: dequeue1"); - - if (msg2.ring_index != 1 || msg2.elt_index != 0) - test1_error ("failed: dequeue1 result"); - if (*(u32 *)svm_msg_q_msg_data (mq, &msg2) != 123) - test1_error ("failed: dequeue1 wrong data"); - - svm_msg_q_free_msg (mq, &msg2); - - for (i = 0; i < 12; i++) - { - if (svm_msg_q_sub (mq, &msg[i], SVM_Q_NOWAIT, 0)) - test1_error ("failed: dequeue2"); - if (i < 8) - { - if (msg[i].ring_index != 0 || msg[i].elt_index != (i + 1) % 8) - test1_error ("failed: dequeue2 result2"); - } - else - { - if (msg[i].ring_index != 1 || msg[i].elt_index != (i - 8) + 1) - test1_error ("failed: dequeue2 result3"); - } - if (*(u32 *)svm_msg_q_msg_data (mq, &msg[i]) != i) - test1_error ("failed: dequeue2 wrong data"); - svm_msg_q_free_msg (mq, &msg[i]); - } - if (mq->rings[0].cursize != 0 || mq->rings[1].cursize != 0) - test1_error ("failed: post dequeue"); - - ssvm_pop_heap (oldheap); - -done: - ssvm_delete (ssvm); - return error; -} - -int -test_svm_message_queue (unformat_input_t * input) -{ - clib_error_t *error = 0; - int verbose = 0; - int test_id = 0; - - while (unformat_check_input (input) != UNFORMAT_END_OF_INPUT) - { - if (unformat (input, "test1")) - test_id = 1; - else - { - error = clib_error_create ("unknown input `%U'\n", - format_unformat_error, input); - goto out; - } - } - - switch (test_id) - { - case 1: - error = test1 (verbose); - } -out: - if (error) - clib_error_report (error); - else - clib_warning ("success"); - - return 0; -} - -int -main (int argc, char *argv[]) -{ - unformat_input_t i; - int r; - - clib_mem_init_thread_safe (0, 256 << 20); - unformat_init_command_line (&i, argv); - r = test_svm_message_queue (&i); - unformat_free (&i); - return r; -} |