diff options
author | Bill Fischofer <bill.fischofer@linaro.org> | 2016-03-06 07:10:32 +1100 |
---|---|---|
committer | Maxim Uvarov <maxim.uvarov@linaro.org> | 2016-04-21 18:54:41 +0300 |
commit | 6d941d37ab8329ec9c2fb7819a11e1b25d22d92f (patch) | |
tree | de0e22d5857d8b9f2ab55856339ba79e426471cd /test | |
parent | 7e4d875d95cbcbac45627d17330e56b99d033ccb (diff) |
validation: rwlock: add tests for new trylock rwlock and rwlock_recursive apis
Signed-off-by: Bill Fischofer <bill.fischofer@linaro.org>
Signed-off-by: Maxim Uvarov <maxim.uvarov@linaro.org>
Diffstat (limited to 'test')
-rw-r--r-- | test/validation/lock/lock.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/test/validation/lock/lock.c b/test/validation/lock/lock.c index 1f79c4d1f..ce7425113 100644 --- a/test/validation/lock/lock.c +++ b/test/validation/lock/lock.c @@ -254,17 +254,33 @@ static void *ticketlock_api_tests(void *arg UNUSED) static void rwlock_api_test(odp_rwlock_t *rw_lock) { + int rc; + odp_rwlock_init(rw_lock); /* CU_ASSERT(odp_rwlock_is_locked(rw_lock) == 0); */ odp_rwlock_read_lock(rw_lock); + + rc = odp_rwlock_read_trylock(rw_lock); + CU_ASSERT(rc == 0); + rc = odp_rwlock_write_trylock(rw_lock); + CU_ASSERT(rc == 0); + odp_rwlock_read_unlock(rw_lock); + rc = odp_rwlock_read_trylock(rw_lock); + if (rc == 1) + odp_rwlock_read_unlock(rw_lock); + odp_rwlock_write_lock(rw_lock); /* CU_ASSERT(odp_rwlock_is_locked(rw_lock) == 1); */ odp_rwlock_write_unlock(rw_lock); /* CU_ASSERT(odp_rwlock_is_locked(rw_lock) == 0); */ + + rc = odp_rwlock_write_trylock(rw_lock); + if (rc == 1) + odp_rwlock_write_unlock(rw_lock); } static void *rwlock_api_tests(void *arg UNUSED) @@ -288,21 +304,33 @@ static void *rwlock_api_tests(void *arg UNUSED) static void rwlock_recursive_api_test(odp_rwlock_recursive_t *rw_lock) { + int rc; + odp_rwlock_recursive_init(rw_lock); /* CU_ASSERT(odp_rwlock_is_locked(rw_lock) == 0); */ odp_rwlock_recursive_read_lock(rw_lock); odp_rwlock_recursive_read_lock(rw_lock); + rc = odp_rwlock_recursive_read_trylock(rw_lock); + CU_ASSERT(rc == 1); + rc = odp_rwlock_recursive_write_trylock(rw_lock); + CU_ASSERT(rc == 0); odp_rwlock_recursive_read_unlock(rw_lock); odp_rwlock_recursive_read_unlock(rw_lock); + odp_rwlock_recursive_read_unlock(rw_lock); odp_rwlock_recursive_write_lock(rw_lock); odp_rwlock_recursive_write_lock(rw_lock); /* CU_ASSERT(odp_rwlock_is_locked(rw_lock) == 1); */ + rc = odp_rwlock_recursive_read_trylock(rw_lock); + CU_ASSERT(rc == 0); + rc = odp_rwlock_recursive_write_trylock(rw_lock); + CU_ASSERT(rc == 1); odp_rwlock_recursive_write_unlock(rw_lock); odp_rwlock_recursive_write_unlock(rw_lock); + odp_rwlock_recursive_write_unlock(rw_lock); /* CU_ASSERT(odp_rwlock_is_locked(rw_lock) == 0); */ } |