X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;f=app%2Ftest%2Ftest_tailq.c;h=c046a8ac5371534f5033429cf3a47abd54bb0c66;hb=a0fd91cefcc054b770dec6d8fb60db0d3145c45a;hp=56656f038f69191ab6fd9fcce0a86be99ee6397c;hpb=9b7e0dbb6c547e256146b0679f0e918b15d10541;p=dpdk.git diff --git a/app/test/test_tailq.c b/app/test/test_tailq.c index 56656f038f..c046a8ac53 100644 --- a/app/test/test_tailq.c +++ b/app/test/test_tailq.c @@ -34,6 +34,7 @@ #include #include #include +#include #include #include @@ -49,40 +50,59 @@ return 1; \ } while (0) -#define DEFAULT_TAILQ (RTE_TAILQ_NUM) +static struct rte_tailq_elem rte_dummy_tailq = { + .name = "dummy", +}; +EAL_REGISTER_TAILQ(rte_dummy_tailq) + +static struct rte_tailq_elem rte_dummy_dyn_tailq = { + .name = "dummy_dyn", +}; +static struct rte_tailq_elem rte_dummy_dyn2_tailq = { + .name = "dummy_dyn", +}; static struct rte_tailq_entry d_elem; +static struct rte_tailq_entry d_dyn_elem; static int -test_tailq_create(void) +test_tailq_early(void) { struct rte_tailq_entry_head *d_head; - unsigned i; - /* create a first tailq and check its non-null */ - d_head = RTE_TAILQ_LOOKUP_BY_IDX(DEFAULT_TAILQ, rte_tailq_entry_head); + d_head = RTE_TAILQ_CAST(rte_dummy_tailq.head, rte_tailq_entry_head); if (d_head == NULL) - do_return("Error allocating dummy_q0\n"); + do_return("Error %s has not been initialised\n", + rte_dummy_tailq.name); - /* check we can add an item to it - */ + /* check we can add an item to it */ TAILQ_INSERT_TAIL(d_head, &d_elem, next); - /* try allocating dummy_q0 again, and check for failure */ - if (RTE_TAILQ_LOOKUP_BY_IDX(DEFAULT_TAILQ, rte_tailq_entry_head) == NULL) - do_return("Error, non-null result returned when attemption to " - "re-allocate a tailq\n"); + return 0; +} + +static int +test_tailq_create(void) +{ + struct rte_tailq_entry_head *d_head; + + /* create a tailq and check its non-null (since we are post-eal init) */ + if ((rte_eal_tailq_register(&rte_dummy_dyn_tailq) < 0) || + (rte_dummy_dyn_tailq.head == NULL)) + do_return("Error allocating %s\n", rte_dummy_dyn_tailq.name); + + d_head = RTE_TAILQ_CAST(rte_dummy_dyn_tailq.head, rte_tailq_entry_head); - /* now fill up the tailq slots available and check we get an error */ - for (i = RTE_TAILQ_NUM; i < RTE_MAX_TAILQ; i++){ - if ((d_head = RTE_TAILQ_LOOKUP_BY_IDX(i, - rte_tailq_entry_head)) == NULL) - break; - } + /* check we can add an item to it */ + TAILQ_INSERT_TAIL(d_head, &d_dyn_elem, next); - /* check that we had an error return before RTE_MAX_TAILQ */ - if (i != RTE_MAX_TAILQ) - do_return("Error, we did not have a reservation as expected\n"); + if (strcmp(rte_dummy_dyn2_tailq.name, rte_dummy_dyn_tailq.name)) + do_return("Error, something is wrong in the tailq test\n"); + + /* try allocating again, and check for failure */ + if (!rte_eal_tailq_register(&rte_dummy_dyn2_tailq)) + do_return("Error, registering the same tailq %s did not fail\n", + rte_dummy_dyn2_tailq.name); return 0; } @@ -94,8 +114,10 @@ test_tailq_lookup(void) struct rte_tailq_entry_head *d_head; struct rte_tailq_entry *d_ptr; - d_head = RTE_TAILQ_LOOKUP_BY_IDX(DEFAULT_TAILQ, rte_tailq_entry_head); - if (d_head == NULL) + d_head = RTE_TAILQ_LOOKUP(rte_dummy_tailq.name, rte_tailq_entry_head); + /* rte_dummy_tailq has been registered by EAL_REGISTER_TAILQ */ + if (d_head == NULL || + d_head != RTE_TAILQ_CAST(rte_dummy_tailq.head, rte_tailq_entry_head)) do_return("Error with tailq lookup\n"); TAILQ_FOREACH(d_ptr, d_head, next) @@ -103,8 +125,19 @@ test_tailq_lookup(void) do_return("Error with tailq returned from lookup - " "expected element not found\n"); + d_head = RTE_TAILQ_LOOKUP(rte_dummy_dyn_tailq.name, rte_tailq_entry_head); + /* rte_dummy_dyn_tailq has been registered by test_tailq_create */ + if (d_head == NULL || + d_head != RTE_TAILQ_CAST(rte_dummy_dyn_tailq.head, rte_tailq_entry_head)) + do_return("Error with tailq lookup\n"); + + TAILQ_FOREACH(d_ptr, d_head, next) + if (d_ptr != &d_dyn_elem) + do_return("Error with tailq returned from lookup - " + "expected element not found\n"); + /* now try a bad/error lookup */ - d_head = RTE_TAILQ_LOOKUP_BY_IDX(RTE_MAX_TAILQ, rte_tailq_entry_head); + d_head = RTE_TAILQ_LOOKUP("coucou", rte_tailq_entry_head); if (d_head != NULL) do_return("Error, lookup does not return NULL for bad tailq name\n"); @@ -115,6 +148,7 @@ static int test_tailq(void) { int ret = 0; + ret |= test_tailq_early(); ret |= test_tailq_create(); ret |= test_tailq_lookup(); return ret;