X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=app%2Ftest%2Ftest_cycles.c;h=f1897979d22fe7d91e07c23ba718b8e9a488bf62;hb=8b3373e7a524233ddb21cd5763cb0de65985b8f0;hp=d8fa5171be66da28108f0142e50c58a9060da6be;hpb=5129044dce1f85ce4950f31bcf90f3886466f06a;p=deb_dpdk.git diff --git a/app/test/test_cycles.c b/app/test/test_cycles.c index d8fa5171..f1897979 100644 --- a/app/test/test_cycles.c +++ b/app/test/test_cycles.c @@ -89,8 +89,49 @@ test_cycles(void) return 0; } -static struct test_command cycles_cmd = { - .command = "cycles_autotest", - .callback = test_cycles, -}; -REGISTER_TEST_COMMAND(cycles_cmd); +REGISTER_TEST_COMMAND(cycles_autotest, test_cycles); + +/* + * rte_delay_us_callback test + * + * - check if callback is correctly registered/unregistered + * + */ + +static unsigned int pattern; +static void my_rte_delay_us(unsigned int us) +{ + pattern += us; +} + +static int +test_user_delay_us(void) +{ + pattern = 0; + + rte_delay_us(2); + if (pattern != 0) + return -1; + + /* register custom delay function */ + rte_delay_us_callback_register(my_rte_delay_us); + + rte_delay_us(2); + if (pattern != 2) + return -1; + + rte_delay_us(3); + if (pattern != 5) + return -1; + + /* restore original delay function */ + rte_delay_us_callback_register(rte_delay_us_block); + + rte_delay_us(3); + if (pattern != 5) + return -1; + + return 0; +} + +REGISTER_TEST_COMMAND(user_delay_us, test_user_delay_us);