minor fix
[cdsspec-compiler.git] / benchmark / cliffc-hashtable / main.cc
index cecaa0cb81524307dc88fe34761ded6b9b2465f7..351c0da7989fecad5c0ec98b20f5da768541d20b 100644 (file)
@@ -51,62 +51,63 @@ class IntWrapper {
 
 cliffc_hashtable<IntWrapper, IntWrapper> *table;
 IntWrapper *val1, *val2;
+IntWrapper *k1, *k2, *k3, *k4, *k5;
+IntWrapper *v1, *v2, *v3, *v4, *v5;
 
 void threadA(void *arg) {
-       IntWrapper *k1 = new IntWrapper(3), *k2 = new IntWrapper(5),
-               *k3 = new IntWrapper(1024), *k4 = new IntWrapper(1025);
-       IntWrapper *v1 = new IntWrapper(1024), *v2 = new IntWrapper(1025),
-               *v3 = new IntWrapper(73), *v4 = new IntWrapper(81);
        table->put(k1, v1);
-       table->put(k2, v2);
+       //table->put(k4, v3);
+       //table->put(v3, v3);
+       
        val1 = table->get(k3);
-       table->put(k3, v3);
+       if (val1 != NULL)
+               model_print("val1: %d\n", val1->_val);
+       else
+               model_print("val1: NULL\n");
+       //table->put(k3, v3);
+       
 }
 
 void threadB(void *arg) {
-       IntWrapper *k1 = new IntWrapper(3), *k2 = new IntWrapper(5),
-               *k3 = new IntWrapper(1024), *k4 = new IntWrapper(1025);
-       IntWrapper *v1 = new IntWrapper(1024), *v2 = new IntWrapper(1025),
-               *v3 = new IntWrapper(73), *v4 = new IntWrapper(81);
+       /*
        table->put(k1, v3);
+       val1 = table->get(k2);
        table->put(k2, v4);
        val1 = table->get(k2);
-}
-
-void threadC(void *arg) {
-       IntWrapper *k1 = new IntWrapper(3), *k2 = new IntWrapper(5),
-               *k3 = new IntWrapper(1024), *k4 = new IntWrapper(1025);
-       IntWrapper *v1 = new IntWrapper(1024), *v2 = new IntWrapper(1025),
-               *v3 = new IntWrapper(73), *v4 = new IntWrapper(81);
-       table->put(k1, v1);
-       table->put(k2, v2);
-       val2 = table->get(k1);
+       */
 }
 
 void threadMain(void *arg) {
-       for (int i = 200; i < 300; i++) {
-               IntWrapper *k = new IntWrapper(i), *v = new IntWrapper(i * 2);
-               table->put(k, v);
-       }
+       table->put(k3, v3);
+       val1 = table->get(k1);
+       if (val1 != NULL)
+               model_print("val1: %d\n", val1->_val);
+       else
+               model_print("val1: NULL\n");
 }
 
 int user_main(int argc, char *argv[]) {
-       thrd_t t1, t2, t3, t4;
-       table = new cliffc_hashtable<IntWrapper, IntWrapper>();
-       val1 = NULL;
-       val2 = NULL;
-       threadMain(NULL);
+       thrd_t t1, t2;
+       table = new cliffc_hashtable<IntWrapper, IntWrapper>(2);
+    k1 = new IntWrapper(3);
+       k2 = new IntWrapper(5);
+       k3 = new IntWrapper(11);
+       k4 = new IntWrapper(7);
+       k5 = new IntWrapper(13);
+
+       v1 = new IntWrapper(1024);
+       v2 = new IntWrapper(47);
+       v3 = new IntWrapper(73);
+       v4 = new IntWrapper(81);
+       v5 = new IntWrapper(99);
 
        thrd_create(&t1, threadA, NULL);
        thrd_create(&t2, threadB, NULL);
-       //thrd_create(&t3, threadC, NULL);
-       //thrd_create(&t4, threadD, NULL);
+       threadMain(NULL);
 
        thrd_join(t1);
        thrd_join(t2);
-       //thrd_join(t3);
-       //thrd_join(t4);
-       
+       /*
        if (val1 == NULL) {
                cout << "val1: NULL" << endl;
        } else {
@@ -118,6 +119,7 @@ int user_main(int argc, char *argv[]) {
        } else {
                cout << val2->get() << endl;
        }
+       */
        return 0;
 }