summaryrefslogtreecommitdiff
path: root/src/test/test_spinlock.c
diff options
context:
space:
mode:
authorbrianluau <brianluau@54d463be-8e91-2dee-dedb-b68131a5f0ec>2012-12-05 02:53:33 +0000
committerbrianluau <brianluau@54d463be-8e91-2dee-dedb-b68131a5f0ec>2012-12-05 02:53:33 +0000
commit60a426c0742b3e7d8c5b557c7578df6eeeea377b (patch)
tree5d01f9ccc2798309f9b13f07c0096ed97c6a85c8 /src/test/test_spinlock.c
parent621db2441f69736a6c8f10d26bf966d5414fac74 (diff)
downloadhercules-60a426c0742b3e7d8c5b557c7578df6eeeea377b.tar.gz
hercules-60a426c0742b3e7d8c5b557c7578df6eeeea377b.tar.bz2
hercules-60a426c0742b3e7d8c5b557c7578df6eeeea377b.tar.xz
hercules-60a426c0742b3e7d8c5b557c7578df6eeeea377b.zip
- Undid r16968: SVN Replaced with source:/trunk/src/@16966 (tid:74924).
[16969:16991/trunk/src/] will be re-committed in the next 24 hours. git-svn-id: https://rathena.svn.sourceforge.net/svnroot/rathena/trunk@16992 54d463be-8e91-2dee-dedb-b68131a5f0ec
Diffstat (limited to 'src/test/test_spinlock.c')
-rw-r--r--src/test/test_spinlock.c160
1 files changed, 77 insertions, 83 deletions
diff --git a/src/test/test_spinlock.c b/src/test/test_spinlock.c
index e6f7dfe52..878ee8bab 100644
--- a/src/test/test_spinlock.c
+++ b/src/test/test_spinlock.c
@@ -8,8 +8,8 @@
#include <stdio.h>
#include <stdlib.h>
-//
-// Simple test for the spinlock implementation to see if it works properly..
+//
+// Simple test for the spinlock implementation to see if it works properly..
//
@@ -23,101 +23,95 @@ static SPIN_LOCK lock;
static int val = 0;
static volatile int32 done_threads = 0;
-static void *worker(void *p)
-{
- register int i;
-
- for (i = 0; i < PERINC; i++) {
- EnterSpinLock(&lock);
- EnterSpinLock(&lock);
-
- val++;
-
- LeaveSpinLock(&lock);
- LeaveSpinLock(&lock);
- }
-
- InterlockedIncrement(&done_threads);
-
- return NULL;
+static void *worker(void *p){
+ register int i;
+
+ for(i = 0; i < PERINC; i++){
+ EnterSpinLock(&lock);
+ EnterSpinLock(&lock);
+
+ val++;
+
+ LeaveSpinLock(&lock);
+ LeaveSpinLock(&lock);
+ }
+
+ InterlockedIncrement(&done_threads);
+
+ return NULL;
}//end: worker()
-int do_init(int argc, char **argv)
-{
- rAthread t[THRC];
- int j, i;
- int ok;
-
- ShowStatus("==========\n");
- ShowStatus("TEST: %u Runs, (%u Threads)\n", LOOPS, THRC);
- ShowStatus("This can take a while\n");
- ShowStatus("\n\n");
-
- ok =0;
- for (j = 0; j < LOOPS; j++) {
- val = 0;
- done_threads = 0;
-
- InitializeSpinLock(&lock);
-
-
- for (i =0; i < THRC; i++) {
- t[i] = rathread_createEx(worker, NULL, 1024*512, RAT_PRIO_NORMAL);
- }
-
-
- while (1) {
- if (InterlockedCompareExchange(&done_threads, THRC, THRC) == THRC)
- break;
-
- rathread_yield();
- }
-
- FinalizeSpinLock(&lock);
-
- // Everything fine?
- if (val != (THRC*PERINC)) {
- printf("FAILED! (Result: %u, Expected: %u)\n", val, (THRC*PERINC));
- } else {
- printf("OK! (Result: %u, Expected: %u)\n", val, (THRC*PERINC));
- ok++;
- }
-
- }
-
-
- if (ok != LOOPS) {
- ShowFatalError("Test failed.\n");
- exit(1);
- } else {
- ShowStatus("Test passed.\n");
- exit(0);
- }
-
-
- return 0;
+int do_init(int argc, char **argv){
+ rAthread t[THRC];
+ int j, i;
+ int ok;
+
+ ShowStatus("==========\n");
+ ShowStatus("TEST: %u Runs, (%u Threads)\n", LOOPS, THRC);
+ ShowStatus("This can take a while\n");
+ ShowStatus("\n\n");
+
+ ok =0;
+ for(j = 0; j < LOOPS; j++){
+ val = 0;
+ done_threads = 0;
+
+ InitializeSpinLock(&lock);
+
+
+ for(i =0; i < THRC; i++){
+ t[i] = rathread_createEx( worker, NULL, 1024*512, RAT_PRIO_NORMAL);
+ }
+
+
+ while(1){
+ if(InterlockedCompareExchange(&done_threads, THRC, THRC) == THRC)
+ break;
+
+ rathread_yield();
+ }
+
+ FinalizeSpinLock(&lock);
+
+ // Everything fine?
+ if(val != (THRC*PERINC) ){
+ printf("FAILED! (Result: %u, Expected: %u)\n", val, (THRC*PERINC) );
+ }else{
+ printf("OK! (Result: %u, Expected: %u)\n", val, (THRC*PERINC) );
+ ok++;
+ }
+
+ }
+
+
+ if(ok != LOOPS){
+ ShowFatalError("Test failed.\n");
+ exit(1);
+ }else{
+ ShowStatus("Test passed.\n");
+ exit(0);
+ }
+
+
+return 0;
}//end: do_init()
-void do_abort()
-{
+void do_abort(){
}//end: do_abort()
-void set_server_type()
-{
- SERVER_TYPE = ATHENA_SERVER_NONE;
+void set_server_type(){
+ SERVER_TYPE = ATHENA_SERVER_NONE;
}//end: set_server_type()
-void do_final()
-{
+void do_final(){
}//end: do_final()
-int parse_console(const char *command)
-{
- return 0;
+int parse_console(const char* command){
+ return 0;
}//end: parse_console