diff options
author | Josh Triplett <josht@us.ibm.com> | 2006-10-04 05:17:16 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-10-04 10:55:31 -0400 |
commit | 11a147013e39ff4cb031395cb78a9d307c4799cd (patch) | |
tree | bbacc6c3cb3cc53e6f92da1bd6632f37a056dfeb /kernel/rcutorture.c | |
parent | 20d2e4283a97665a3db78c60dfa342a0c7c1b180 (diff) |
[PATCH] rcu: add rcu_bh_sync torture type to rcutorture
Use the newly-generic synchronous deferred free function to implement torture
testing for rcu_bh using synchronize_rcu_bh rather than the asynchronous
call_rcu_bh.
Signed-off-by: Josh Triplett <josh@freedesktop.org>
Acked-by: Paul E. McKenney <paulmck@us.ibm.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'kernel/rcutorture.c')
-rw-r--r-- | kernel/rcutorture.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/kernel/rcutorture.c b/kernel/rcutorture.c index 1c329df60bcc..0f0ff1556b5d 100644 --- a/kernel/rcutorture.c +++ b/kernel/rcutorture.c | |||
@@ -370,6 +370,19 @@ static struct rcu_torture_ops rcu_bh_ops = { | |||
370 | .name = "rcu_bh" | 370 | .name = "rcu_bh" |
371 | }; | 371 | }; |
372 | 372 | ||
373 | static struct rcu_torture_ops rcu_bh_sync_ops = { | ||
374 | .init = rcu_sync_torture_init, | ||
375 | .cleanup = NULL, | ||
376 | .readlock = rcu_bh_torture_read_lock, | ||
377 | .readdelay = rcu_read_delay, /* just reuse rcu's version. */ | ||
378 | .readunlock = rcu_bh_torture_read_unlock, | ||
379 | .completed = rcu_bh_torture_completed, | ||
380 | .deferredfree = rcu_sync_torture_deferred_free, | ||
381 | .sync = rcu_bh_torture_synchronize, | ||
382 | .stats = NULL, | ||
383 | .name = "rcu_bh_sync" | ||
384 | }; | ||
385 | |||
373 | /* | 386 | /* |
374 | * Definitions for srcu torture testing. | 387 | * Definitions for srcu torture testing. |
375 | */ | 388 | */ |
@@ -452,7 +465,8 @@ static struct rcu_torture_ops srcu_ops = { | |||
452 | }; | 465 | }; |
453 | 466 | ||
454 | static struct rcu_torture_ops *torture_ops[] = | 467 | static struct rcu_torture_ops *torture_ops[] = |
455 | { &rcu_ops, &rcu_sync_ops, &rcu_bh_ops, &srcu_ops, NULL }; | 468 | { &rcu_ops, &rcu_sync_ops, &rcu_bh_ops, &rcu_bh_sync_ops, &srcu_ops, |
469 | NULL }; | ||
456 | 470 | ||
457 | /* | 471 | /* |
458 | * RCU torture writer kthread. Repeatedly substitutes a new structure | 472 | * RCU torture writer kthread. Repeatedly substitutes a new structure |