projects
/
urcu.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
wfcqueue: implement C++ API based on function overloading
[urcu.git]
/
tests
/
benchmark
/
test_urcu_qsbr_timing.c
diff --git
a/tests/benchmark/test_urcu_qsbr_timing.c
b/tests/benchmark/test_urcu_qsbr_timing.c
index 9b5195d9605e4ba914cf76cdeab14f2c63019c12..09b9ca963c9133496cb3f2cc12512ede8e70089a 100644
(file)
--- a/
tests/benchmark/test_urcu_qsbr_timing.c
+++ b/
tests/benchmark/test_urcu_qsbr_timing.c
@@
-28,10
+28,10
@@
#include <sys/wait.h>
#include <unistd.h>
#include <stdio.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdio.h>
-#include <assert.h>
#include <errno.h>
#include <urcu/arch.h>
#include <errno.h>
#include <urcu/arch.h>
+#include <urcu/assert.h>
#include "thread-id.h"
#define _LGPL_SOURCE
#include "thread-id.h"
#define _LGPL_SOURCE
@@
-39,6
+39,7
@@
pthread_mutex_t rcu_copy_mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_mutex_t rcu_copy_mutex = PTHREAD_MUTEX_INITIALIZER;
+static
void rcu_copy_mutex_lock(void)
{
int ret;
void rcu_copy_mutex_lock(void)
{
int ret;
@@
-49,6
+50,7
@@
void rcu_copy_mutex_lock(void)
}
}
}
}
+static
void rcu_copy_mutex_unlock(void)
{
int ret;
void rcu_copy_mutex_unlock(void)
{
int ret;
@@
-80,14
+82,15
@@
static int num_write;
#define NR_READ num_read
#define NR_WRITE num_write
#define NR_READ num_read
#define NR_WRITE num_write
-static cycles_t __attribute__((aligned(CAA_CACHE_LINE_SIZE))) *reader_time;
-static cycles_t __attribute__((aligned(CAA_CACHE_LINE_SIZE))) *writer_time;
+static c
aa_c
ycles_t __attribute__((aligned(CAA_CACHE_LINE_SIZE))) *reader_time;
+static c
aa_c
ycles_t __attribute__((aligned(CAA_CACHE_LINE_SIZE))) *writer_time;
+static
void *thr_reader(void *arg)
{
void *thr_reader(void *arg)
{
- int i, j;
+
unsigned
int i, j;
struct test_array *local_ptr;
struct test_array *local_ptr;
- cycles_t time1, time2;
+ c
aa_c
ycles_t time1, time2;
printf("thread_begin %s, tid %lu\n",
"reader", urcu_get_thread_id());
printf("thread_begin %s, tid %lu\n",
"reader", urcu_get_thread_id());
@@
-101,7
+104,7
@@
void *thr_reader(void *arg)
_rcu_read_lock();
local_ptr = _rcu_dereference(test_rcu_pointer);
if (local_ptr) {
_rcu_read_lock();
local_ptr = _rcu_dereference(test_rcu_pointer);
if (local_ptr) {
- assert(local_ptr->a == 8);
+
urcu_posix_
assert(local_ptr->a == 8);
}
_rcu_read_unlock();
}
}
_rcu_read_unlock();
}
@@
-120,11
+123,12
@@
void *thr_reader(void *arg)
}
}
+static
void *thr_writer(void *arg)
{
void *thr_writer(void *arg)
{
- int i, j;
+
unsigned
int i, j;
struct test_array *new, *old;
struct test_array *new, *old;
- cycles_t time1, time2;
+ c
aa_c
ycles_t time1, time2;
printf("thread_begin %s, tid %lu\n",
"writer", urcu_get_thread_id());
printf("thread_begin %s, tid %lu\n",
"writer", urcu_get_thread_id());
@@
-137,7
+141,7
@@
void *thr_writer(void *arg)
rcu_copy_mutex_lock();
old = test_rcu_pointer;
if (old) {
rcu_copy_mutex_lock();
old = test_rcu_pointer;
if (old) {
- assert(old->a == 8);
+
urcu_posix_
assert(old->a == 8);
}
new->a = 8;
old = rcu_xchg_pointer(&test_rcu_pointer, new);
}
new->a = 8;
old = rcu_xchg_pointer(&test_rcu_pointer, new);
@@
-165,8
+169,8
@@
int main(int argc, char **argv)
pthread_t *tid_reader, *tid_writer;
void *tret;
int i;
pthread_t *tid_reader, *tid_writer;
void *tret;
int i;
- cycles_t tot_rtime = 0;
- cycles_t tot_wtime = 0;
+ c
aa_c
ycles_t tot_rtime = 0;
+ c
aa_c
ycles_t tot_wtime = 0;
if (argc < 2) {
printf("Usage : %s nr_readers nr_writers\n", argv[0]);
if (argc < 2) {
printf("Usage : %s nr_readers nr_writers\n", argv[0]);
This page took
0.02443 seconds
and
4
git commands to generate.