5 #include <linux/module.h>
6 #include <linux/proc_fs.h>
7 #include <linux/sched.h>
8 #include <linux/timex.h>
9 #include <linux/kthread.h>
10 #include <linux/delay.h>
11 #include <linux/hardirq.h>
12 #include <linux/module.h>
13 #include <linux/percpu.h>
14 #include <linux/spinlock.h>
15 #include <asm/ptrace.h>
16 #include <linux/wbias-rwlock.h>
18 /* Test with no contention duration, in seconds */
19 #define SINGLE_WRITER_TEST_DURATION 10
20 #define SINGLE_READER_TEST_DURATION 10
21 #define MULTIPLE_READERS_TEST_DURATION 10
23 /* Test duration, in seconds */
24 #define TEST_DURATION 60
28 #define NR_TRYLOCK_WRITERS 1
29 #define NR_NPREADERS 2
30 #define NR_TRYLOCK_READERS 1
33 * 1 : test standard rwlock
34 * 0 : test wbiasrwlock
36 #define TEST_STD_RWLOCK 0
39 * 1 : test with thread and interrupt readers.
40 * 0 : test only with thread readers.
42 #define TEST_INTERRUPTS 1
45 #define NR_INTERRUPT_READERS 1
46 #define NR_TRYLOCK_INTERRUPT_READERS 1
48 #define NR_INTERRUPT_READERS 0
49 #define NR_TRYLOCK_INTERRUPT_READERS 0
53 * 1 : test with thread preemption readers.
54 * 0 : test only with non-preemptable thread readers.
56 #define TEST_PREEMPT 1
66 * Writer iteration delay, in us. 0 for busy loop. Caution : writers can
69 #define WRITER_DELAY 100
70 #define TRYLOCK_WRITER_DELAY 1000
73 * Number of iterations after which a trylock writer fails.
74 * -1 for infinite loop.
76 #define TRYLOCK_WRITERS_FAIL_ITER 100
78 /* Thread and interrupt reader delay, in ms */
79 #define THREAD_READER_DELAY 0 /* busy loop */
80 #define INTERRUPT_READER_DELAY 100
82 static int var
[NR_VARS
];
83 static struct task_struct
*preader_threads
[NR_PREADERS
];
84 static struct task_struct
*npreader_threads
[NR_NPREADERS
];
85 static struct task_struct
*trylock_reader_threads
[NR_TRYLOCK_READERS
];
86 static struct task_struct
*writer_threads
[NR_WRITERS
];
87 static struct task_struct
*trylock_writer_threads
[NR_TRYLOCK_WRITERS
];
88 static struct task_struct
*interrupt_reader
[NR_INTERRUPT_READERS
];
89 static struct task_struct
*trylock_interrupt_reader
[NR_TRYLOCK_INTERRUPT_READERS
];
93 static DEFINE_RWLOCK(std_rw_lock
);
95 #define wrap_read_lock() read_lock(&std_rw_lock)
96 #define wrap_read_trylock() read_trylock(&std_rw_lock)
97 #define wrap_read_unlock() read_unlock(&std_rw_lock)
99 #define wrap_read_lock_inatomic() read_lock(&std_rw_lock)
100 #define wrap_read_trylock_inatomic() read_trylock(&std_rw_lock)
101 #define wrap_read_unlock_inatomic() read_unlock(&std_rw_lock)
103 #define wrap_read_lock_irq() read_lock(&std_rw_lock)
104 #define wrap_read_trylock_irq() read_trylock(&std_rw_lock)
105 #define wrap_read_unlock_irq() read_unlock(&std_rw_lock)
107 #if (TEST_INTERRUPTS)
108 #define wrap_write_lock() write_lock_irq(&std_rw_lock)
109 #define wrap_write_unlock() write_unlock_irq(&std_rw_lock)
111 #define wrap_write_lock() write_lock(&std_rw_lock)
112 #define wrap_write_unlock() write_unlock(&std_rw_lock)
117 static DEFINE_WBIAS_RWLOCK(wbiasrwlock
);
119 #define wrap_read_lock() wbias_read_lock(&wbiasrwlock)
120 #define wrap_read_trylock() wbias_read_trylock(&wbiasrwlock)
121 #define wrap_read_unlock() wbias_read_unlock(&wbiasrwlock)
123 #define wrap_read_lock_inatomic() wbias_read_lock_inatomic(&wbiasrwlock)
124 #define wrap_read_trylock_inatomic() \
125 wbias_read_trylock_inatomic(&wbiasrwlock)
126 #define wrap_read_unlock_inatomic() \
127 wbias_read_unlock_inatomic(&wbiasrwlock)
129 #define wrap_read_lock_irq() wbias_read_lock_irq(&wbiasrwlock)
130 #define wrap_read_trylock_irq() wbias_read_trylock_irq(&wbiasrwlock)
131 #define wrap_read_unlock_irq() wbias_read_unlock_irq(&wbiasrwlock)
133 #if (TEST_INTERRUPTS)
134 #define wrap_write_lock() wbias_write_lock_irq(&wbiasrwlock)
135 #define wrap_write_unlock() wbias_write_unlock_irq(&wbiasrwlock)
136 #define wrap_write_trylock_else_subscribe() \
137 wbias_write_trylock_irq_else_subscribe(&wbiasrwlock)
138 #define wrap_write_trylock_subscribed() \
139 wbias_write_trylock_irq_subscribed(&wbiasrwlock)
142 #define wrap_write_lock() wbias_write_lock(&wbiasrwlock)
143 #define wrap_write_unlock() wbias_write_unlock(&wbiasrwlock)
144 #define wrap_write_trylock_else_subscribe() \
145 wbias_write_trylock_else_subscribe(&wbiasrwlock)
146 #define wrap_write_trylock_subscribed() \
147 wbias_write_trylock_subscribed(&wbiasrwlock)
150 #define wrap_write_lock() wbias_write_lock_atomic(&wbiasrwlock)
151 #define wrap_write_unlock() wbias_write_unlock_atomic(&wbiasrwlock)
152 #define wrap_write_trylock_else_subscribe() \
153 wbias_write_trylock_atomic_else_subscribe(&wbiasrwlock)
154 #define wrap_write_trylock_subscribed() \
155 wbias_write_trylock_atomic_subscribed(&wbiasrwlock)
161 static cycles_t cycles_calibration_min
,
162 cycles_calibration_avg
,
163 cycles_calibration_max
;
165 static inline cycles_t
calibrate_cycles(cycles_t cycles
)
167 return cycles
- cycles_calibration_avg
;
170 struct proc_dir_entry
*pentry
= NULL
;
172 static int p_or_np_reader_thread(const char *typename
,
173 void *data
, int preemptable
)
177 unsigned long iter
= 0;
178 cycles_t time1
, time2
, delay
, delaymax
= 0, delaymin
= ULLONG_MAX
,
181 printk("%s/%lu runnning\n", typename
, (unsigned long)data
);
187 time1
= get_cycles();
191 wrap_read_lock_inatomic();
196 time2
= get_cycles();
198 delay
= time2
- time1
;
199 delaymax
= max(delaymax
, delay
);
200 delaymin
= min(delaymin
, delay
);
203 for (i
= 1; i
< NR_VARS
; i
++) {
207 "Unequal cur %d/prev %d at i %d, iter %lu "
208 "in thread\n", cur
, prev
, i
, iter
);
212 wrap_read_unlock_inatomic();
217 if (THREAD_READER_DELAY
)
218 msleep(THREAD_READER_DELAY
);
219 } while (!kthread_should_stop());
221 printk("%s/%lu iterations : %lu", typename
,
222 (unsigned long)data
, iter
);
225 printk("%s/%lu iterations : %lu, "
226 "lock delay [min,avg,max] %llu,%llu,%llu cycles\n",
228 (unsigned long)data
, iter
,
229 calibrate_cycles(delaymin
),
230 calibrate_cycles(delayavg
),
231 calibrate_cycles(delaymax
));
236 static int preader_thread(void *data
)
238 return p_or_np_reader_thread("preader_thread", data
, 1);
241 static int npreader_thread(void *data
)
243 return p_or_np_reader_thread("npreader_thread", data
, 0);
246 static int trylock_reader_thread(void *data
)
250 unsigned long iter
= 0, success_iter
= 0;
252 printk("trylock_reader_thread/%lu runnning\n", (unsigned long)data
);
254 while (!wrap_read_trylock())
258 for (i
= 1; i
< NR_VARS
; i
++) {
262 "Unequal cur %d/prev %d at i %d, iter %lu "
263 "in thread\n", cur
, prev
, i
, iter
);
266 if (THREAD_READER_DELAY
)
267 msleep(THREAD_READER_DELAY
);
268 } while (!kthread_should_stop());
269 printk("trylock_reader_thread/%lu iterations : %lu, "
270 "successful iterations : %lu\n",
271 (unsigned long)data
, iter
, success_iter
);
275 DEFINE_PER_CPU(cycles_t
, int_delaymin
);
276 DEFINE_PER_CPU(cycles_t
, int_delayavg
);
277 DEFINE_PER_CPU(cycles_t
, int_delaymax
);
278 DEFINE_PER_CPU(cycles_t
, int_ipi_nr
);
280 static void interrupt_reader_ipi(void *data
)
284 cycles_t time1
, time2
;
285 cycles_t
*delaymax
, *delaymin
, *delayavg
, *ipi_nr
, delay
;
288 * Skip the ipi caller, not in irq context.
293 delaymax
= &per_cpu(int_delaymax
, smp_processor_id());
294 delaymin
= &per_cpu(int_delaymin
, smp_processor_id());
295 delayavg
= &per_cpu(int_delayavg
, smp_processor_id());
296 ipi_nr
= &per_cpu(int_ipi_nr
, smp_processor_id());
299 time1
= get_cycles();
302 wrap_read_lock_irq();
305 time2
= get_cycles();
307 delay
= time2
- time1
;
308 *delaymax
= max(*delaymax
, delay
);
309 *delaymin
= min(*delaymin
, delay
);
313 for (i
= 1; i
< NR_VARS
; i
++) {
317 "Unequal cur %d/prev %d at i %d in interrupt\n",
320 wrap_read_unlock_irq();
323 DEFINE_PER_CPU(unsigned long, trylock_int_iter
);
324 DEFINE_PER_CPU(unsigned long, trylock_int_success
);
326 static void trylock_interrupt_reader_ipi(void *data
)
332 * Skip the ipi caller, not in irq context.
337 per_cpu(trylock_int_iter
, smp_processor_id())++;
338 while (!wrap_read_trylock_irq())
339 per_cpu(trylock_int_iter
, smp_processor_id())++;
340 per_cpu(trylock_int_success
, smp_processor_id())++;
342 for (i
= 1; i
< NR_VARS
; i
++) {
346 "Unequal cur %d/prev %d at i %d in interrupt\n",
349 wrap_read_unlock_irq();
353 static int interrupt_reader_thread(void *data
)
355 unsigned long iter
= 0;
358 for_each_online_cpu(i
) {
359 per_cpu(int_delaymax
, i
) = 0;
360 per_cpu(int_delaymin
, i
) = ULLONG_MAX
;
361 per_cpu(int_delayavg
, i
) = 0;
362 per_cpu(int_ipi_nr
, i
) = 0;
366 on_each_cpu(interrupt_reader_ipi
, NULL
, 0);
367 if (INTERRUPT_READER_DELAY
)
368 msleep(INTERRUPT_READER_DELAY
);
369 } while (!kthread_should_stop());
370 printk("interrupt_reader_thread/%lu iterations : %lu\n",
371 (unsigned long)data
, iter
);
372 for_each_online_cpu(i
) {
373 if (!per_cpu(int_ipi_nr
, i
))
375 per_cpu(int_delayavg
, i
) /= per_cpu(int_ipi_nr
, i
);
376 printk("interrupt readers on CPU %i, "
377 "lock delay [min,avg,max] %llu,%llu,%llu cycles\n",
379 calibrate_cycles(per_cpu(int_delaymin
, i
)),
380 calibrate_cycles(per_cpu(int_delayavg
, i
)),
381 calibrate_cycles(per_cpu(int_delaymax
, i
)));
386 static int trylock_interrupt_reader_thread(void *data
)
388 unsigned long iter
= 0;
393 on_each_cpu(trylock_interrupt_reader_ipi
, NULL
, 0);
394 if (INTERRUPT_READER_DELAY
)
395 msleep(INTERRUPT_READER_DELAY
);
396 } while (!kthread_should_stop());
397 printk("trylock_interrupt_reader_thread/%lu iterations : %lu\n",
398 (unsigned long)data
, iter
);
399 for_each_online_cpu(i
) {
400 printk("trylock interrupt readers on CPU %i, "
402 "successful iterations : %lu\n",
403 i
, per_cpu(trylock_int_iter
, i
),
404 per_cpu(trylock_int_success
, i
));
405 per_cpu(trylock_int_iter
, i
) = 0;
406 per_cpu(trylock_int_success
, i
) = 0;
411 static int writer_thread(void *data
)
415 unsigned long iter
= 0;
416 cycles_t time1
, time2
, delay
, delaymax
= 0, delaymin
= ULLONG_MAX
,
419 printk("writer_thread/%lu runnning\n", (unsigned long)data
);
422 //preempt_disable(); /* for get_cycles accuracy */
424 time1
= get_cycles();
430 time2
= get_cycles();
432 delay
= time2
- time1
;
433 delaymax
= max(delaymax
, delay
);
434 delaymin
= min(delaymin
, delay
);
436 new = (int)get_cycles();
437 for (i
= 0; i
< NR_VARS
; i
++) {
443 //preempt_enable(); /* for get_cycles accuracy */
444 if (WRITER_DELAY
> 0)
445 udelay(WRITER_DELAY
);
446 } while (!kthread_should_stop());
448 printk("writer_thread/%lu iterations : %lu, "
449 "lock delay [min,avg,max] %llu,%llu,%llu cycles\n",
450 (unsigned long)data
, iter
,
451 calibrate_cycles(delaymin
),
452 calibrate_cycles(delayavg
),
453 calibrate_cycles(delaymax
));
457 #if (TEST_STD_RWLOCK)
458 static int trylock_writer_thread(void *data
)
462 unsigned long iter
= 0, success
= 0, fail
= 0;
464 printk("trylock_writer_thread/%lu runnning\n", (unsigned long)data
);
466 #if (TEST_INTERRUPTS)
467 /* std write trylock cannot disable interrupts. */
471 #if (TRYLOCK_WRITERS_FAIL_ITER == -1)
474 if (write_trylock(&std_rw_lock
))
478 for (i
= 0; i
< TRYLOCK_WRITERS_FAIL_ITER
; i
++) {
480 if (write_trylock(&std_rw_lock
))
485 #if (TEST_INTERRUPTS)
491 new = (int)get_cycles();
492 for (i
= 0; i
< NR_VARS
; i
++) {
495 #if (TEST_INTERRUPTS)
496 write_unlock_irq(&std_rw_lock
);
498 write_unlock(&std_rw_lock
);
501 if (TRYLOCK_WRITER_DELAY
> 0)
502 udelay(TRYLOCK_WRITER_DELAY
);
503 } while (!kthread_should_stop());
504 printk("trylock_writer_thread/%lu iterations : "
505 "[try,success,fail after %d try], "
507 (unsigned long)data
, TRYLOCK_WRITERS_FAIL_ITER
,
508 iter
, success
, fail
);
512 #else /* !TEST_STD_RWLOCK */
514 static int trylock_writer_thread(void *data
)
518 unsigned long iter
= 0, success
= 0, fail
= 0;
520 printk("trylock_writer_thread/%lu runnning\n", (unsigned long)data
);
523 if (wrap_write_trylock_else_subscribe())
526 #if (TRYLOCK_WRITERS_FAIL_ITER == -1)
529 if (wrap_write_trylock_subscribed())
533 for (i
= 0; i
< TRYLOCK_WRITERS_FAIL_ITER
- 1; i
++) {
535 if (wrap_write_trylock_subscribed())
540 wbias_write_unsubscribe(&wbiasrwlock
);
544 new = (int)get_cycles();
545 for (i
= 0; i
< NR_VARS
; i
++) {
550 if (TRYLOCK_WRITER_DELAY
> 0)
551 udelay(TRYLOCK_WRITER_DELAY
);
552 } while (!kthread_should_stop());
553 printk("trylock_writer_thread/%lu iterations : "
554 "[try,success,fail after %d try], "
556 (unsigned long)data
, TRYLOCK_WRITERS_FAIL_ITER
,
557 iter
, success
, fail
);
561 #endif /* TEST_STD_RWLOCK */
563 static void wbias_rwlock_create(void)
567 for (i
= 0; i
< NR_PREADERS
; i
++) {
568 printk("starting preemptable reader thread %lu\n", i
);
569 preader_threads
[i
] = kthread_run(preader_thread
, (void *)i
,
570 "wbiasrwlock_preader");
571 BUG_ON(!preader_threads
[i
]);
574 for (i
= 0; i
< NR_NPREADERS
; i
++) {
575 printk("starting non-preemptable reader thread %lu\n", i
);
576 npreader_threads
[i
] = kthread_run(npreader_thread
, (void *)i
,
577 "wbiasrwlock_npreader");
578 BUG_ON(!npreader_threads
[i
]);
581 for (i
= 0; i
< NR_TRYLOCK_READERS
; i
++) {
582 printk("starting trylock reader thread %lu\n", i
);
583 trylock_reader_threads
[i
] = kthread_run(trylock_reader_thread
,
584 (void *)i
, "wbiasrwlock_trylock_reader");
585 BUG_ON(!trylock_reader_threads
[i
]);
587 for (i
= 0; i
< NR_INTERRUPT_READERS
; i
++) {
588 printk("starting interrupt reader %lu\n", i
);
589 interrupt_reader
[i
] = kthread_run(interrupt_reader_thread
,
591 "wbiasrwlock_interrupt_reader");
593 for (i
= 0; i
< NR_TRYLOCK_INTERRUPT_READERS
; i
++) {
594 printk("starting trylock interrupt reader %lu\n", i
);
595 trylock_interrupt_reader
[i
] =
596 kthread_run(trylock_interrupt_reader_thread
,
597 (void *)i
, "wbiasrwlock_trylock_interrupt_reader");
599 for (i
= 0; i
< NR_WRITERS
; i
++) {
600 printk("starting writer thread %lu\n", i
);
601 writer_threads
[i
] = kthread_run(writer_thread
, (void *)i
,
602 "wbiasrwlock_writer");
603 BUG_ON(!writer_threads
[i
]);
605 for (i
= 0; i
< NR_TRYLOCK_WRITERS
; i
++) {
606 printk("starting trylock writer thread %lu\n", i
);
607 trylock_writer_threads
[i
] = kthread_run(trylock_writer_thread
,
608 (void *)i
, "wbiasrwlock_trylock_writer");
609 BUG_ON(!trylock_writer_threads
[i
]);
613 static void wbias_rwlock_stop(void)
617 for (i
= 0; i
< NR_WRITERS
; i
++)
618 kthread_stop(writer_threads
[i
]);
619 for (i
= 0; i
< NR_TRYLOCK_WRITERS
; i
++)
620 kthread_stop(trylock_writer_threads
[i
]);
621 for (i
= 0; i
< NR_NPREADERS
; i
++)
622 kthread_stop(npreader_threads
[i
]);
623 for (i
= 0; i
< NR_PREADERS
; i
++)
624 kthread_stop(preader_threads
[i
]);
625 for (i
= 0; i
< NR_TRYLOCK_READERS
; i
++)
626 kthread_stop(trylock_reader_threads
[i
]);
627 for (i
= 0; i
< NR_INTERRUPT_READERS
; i
++)
628 kthread_stop(interrupt_reader
[i
]);
629 for (i
= 0; i
< NR_TRYLOCK_INTERRUPT_READERS
; i
++)
630 kthread_stop(trylock_interrupt_reader
[i
]);
634 static void perform_test(const char *name
, void (*callback
)(void))
636 printk("%s\n", name
);
640 static int my_open(struct inode
*inode
, struct file
*file
)
643 cycles_t time1
, time2
, delay
;
645 printk("** get_cycles calibration **\n");
646 cycles_calibration_min
= ULLONG_MAX
;
647 cycles_calibration_avg
= 0;
648 cycles_calibration_max
= 0;
651 for (i
= 0; i
< 10; i
++) {
653 time1
= get_cycles();
656 time2
= get_cycles();
658 delay
= time2
- time1
;
659 cycles_calibration_min
= min(cycles_calibration_min
, delay
);
660 cycles_calibration_avg
+= delay
;
661 cycles_calibration_max
= max(cycles_calibration_max
, delay
);
663 cycles_calibration_avg
/= 10;
666 printk("get_cycles takes [min,avg,max] %llu,%llu,%llu cycles, "
667 "results calibrated on avg\n",
668 cycles_calibration_min
,
669 cycles_calibration_avg
,
670 cycles_calibration_max
);
673 printk("** Single writer test, no contention **\n");
674 wbias_rwlock_profile_latency_reset();
675 writer_threads
[0] = kthread_run(writer_thread
, (void *)0,
676 "wbiasrwlock_writer");
677 BUG_ON(!writer_threads
[0]);
678 ssleep(SINGLE_WRITER_TEST_DURATION
);
679 kthread_stop(writer_threads
[0]);
682 wbias_rwlock_profile_latency_print();
684 printk("** Single trylock writer test, no contention **\n");
685 wbias_rwlock_profile_latency_reset();
686 trylock_writer_threads
[0] = kthread_run(trylock_writer_thread
,
688 "trylock_wbiasrwlock_writer");
689 BUG_ON(!trylock_writer_threads
[0]);
690 ssleep(SINGLE_WRITER_TEST_DURATION
);
691 kthread_stop(trylock_writer_threads
[0]);
694 wbias_rwlock_profile_latency_print();
696 printk("** Single preemptable reader test, no contention **\n");
697 wbias_rwlock_profile_latency_reset();
698 preader_threads
[0] = kthread_run(preader_thread
, (void *)0,
699 "wbiasrwlock_preader");
700 BUG_ON(!preader_threads
[0]);
701 ssleep(SINGLE_READER_TEST_DURATION
);
702 kthread_stop(preader_threads
[0]);
705 wbias_rwlock_profile_latency_print();
707 printk("** Single non-preemptable reader test, no contention **\n");
708 wbias_rwlock_profile_latency_reset();
709 npreader_threads
[0] = kthread_run(npreader_thread
, (void *)0,
710 "wbiasrwlock_npreader");
711 BUG_ON(!npreader_threads
[0]);
712 ssleep(SINGLE_READER_TEST_DURATION
);
713 kthread_stop(npreader_threads
[0]);
716 wbias_rwlock_profile_latency_print();
718 printk("** Multiple p/non-p readers test, no contention **\n");
719 wbias_rwlock_profile_latency_reset();
720 for (i
= 0; i
< NR_PREADERS
; i
++) {
721 printk("starting preader thread %lu\n", i
);
722 preader_threads
[i
] = kthread_run(preader_thread
, (void *)i
,
723 "wbiasrwlock_preader");
724 BUG_ON(!preader_threads
[i
]);
726 for (i
= 0; i
< NR_NPREADERS
; i
++) {
727 printk("starting npreader thread %lu\n", i
);
728 npreader_threads
[i
] = kthread_run(npreader_thread
, (void *)i
,
729 "wbiasrwlock_npreader");
730 BUG_ON(!npreader_threads
[i
]);
732 ssleep(SINGLE_READER_TEST_DURATION
);
733 for (i
= 0; i
< NR_NPREADERS
; i
++)
734 kthread_stop(npreader_threads
[i
]);
735 for (i
= 0; i
< NR_PREADERS
; i
++)
736 kthread_stop(preader_threads
[i
]);
739 wbias_rwlock_profile_latency_print();
741 printk("** High contention test **\n");
742 wbias_rwlock_profile_latency_reset();
743 perform_test("wbias-rwlock-create", wbias_rwlock_create
);
744 ssleep(TEST_DURATION
);
745 perform_test("wbias-rwlock-stop", wbias_rwlock_stop
);
747 wbias_rwlock_profile_latency_print();
753 static struct file_operations my_operations
= {
757 int init_module(void)
759 pentry
= create_proc_entry("testwbiasrwlock", 0444, NULL
);
761 pentry
->proc_fops
= &my_operations
;
763 printk("PTHREAD_ROFFSET : %016lX\n", PTHREAD_ROFFSET
);
764 printk("PTHREAD_RMASK : %016lX\n", PTHREAD_RMASK
);
765 printk("NPTHREAD_ROFFSET : %016lX\n", NPTHREAD_ROFFSET
);
766 printk("NPTHREAD_RMASK : %016lX\n", NPTHREAD_RMASK
);
767 printk("SOFTIRQ_ROFFSET : %016lX\n", SOFTIRQ_ROFFSET
);
768 printk("SOFTIRQ_RMASK : %016lX\n", SOFTIRQ_RMASK
);
769 printk("HARDIRQ_ROFFSET : %016lX\n", HARDIRQ_ROFFSET
);
770 printk("HARDIRQ_RMASK : %016lX\n", HARDIRQ_RMASK
);
771 printk("PTHREAD_WOFFSET : %016lX\n", PTHREAD_WOFFSET
);
772 printk("PTHREAD_WMASK : %016lX\n", PTHREAD_WMASK
);
773 printk("NPTHREAD_WOFFSET : %016lX\n", NPTHREAD_WOFFSET
);
774 printk("NPTHREAD_WMASK : %016lX\n", NPTHREAD_WMASK
);
775 printk("WRITER_MUTEX : %016lX\n", WRITER_MUTEX
);
776 printk("SOFTIRQ_WMASK : %016lX\n", SOFTIRQ_WMASK
);
777 printk("HARDIRQ_WMASK : %016lX\n", HARDIRQ_WMASK
);
782 void cleanup_module(void)
784 remove_proc_entry("testwbiasrwlock", NULL
);
787 MODULE_LICENSE("GPL");
788 MODULE_AUTHOR("Mathieu Desnoyers");
789 MODULE_DESCRIPTION("wbias rwlock test");