fix rcu spec
[cdsspec-compiler.git] / benchmark / cliffc-hashtable / main.cc
index 7641fc0a4b7d7cb1da9c47110828591ffb1ddac3..9e6365bf5f7c6147105941e6d6321730f1a21f7c 100644 (file)
@@ -35,6 +35,10 @@ class IntWrapper {
                int hashCode() {
                        return _val;
                }
+               
+               bool operator==(const IntWrapper& rhs) {
+                       return false;
+               }
 
                bool equals(const void *another) {
                        if (another == NULL)
@@ -45,33 +49,72 @@ class IntWrapper {
                }
 };
 
-
-cliffc_hashtable<IntWrapper, IntWrapper> table;
-IntWrapper *val;
+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(3), k2(4), v1(1), v2(2);
-       table.put(k1, v1);
-       table.put(k2, v2);
+       table->put(k1, v1);
+       //table->put(k2, v2);
+       //table->put(k3, v3);
+       /*
+       val1 = table->get(k3);
+       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(3), k2(4), v1(1), v2(2);
-       val = table.get(k2);
+}
+
+void threadMain(void *arg) {
+       //table->put(k3, v3);
+       val2 = table->get(k1);
+       if (val2 != NULL)
+               model_print("val2: %d\n", val1->_val);
+       else
+               model_print("val2: NULL\n");
 }
 
 int user_main(int argc, char *argv[]) {
        thrd_t t1, t2;
-       val = new IntWrapper(0);
+       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);
+       threadMain(NULL);
 
        thrd_join(t1);
-       thrd_join(t2);/*
-       if (val == NULL) {
-               cout << "NULL" << endl;
+       thrd_join(t2);
+       /*
+       if (val1 == NULL) {
+               cout << "val1: NULL" << endl;
+       } else {
+               cout << val1->get() << endl;
+       }
+       //MODEL_ASSERT(val1 == NULL || val1->get() == 2 || val1->get() == 81);
+       if (val2 == NULL) {
+               cout << "val2: NULL" << endl;
        } else {
-               cout << val->get() << endl;
-       }*/
+               cout << val2->get() << endl;
+       }
+       */
        return 0;
 }
+