save
[cdsspec-compiler.git] / benchmark / cliffc-hashtable / main.cc
1 #include <iostream>
2 #include <threads.h>
3 #include "cliffc_hashtable.h"
4
5 using namespace std;
6
7 template<typename TypeK, typename TypeV>
8 slot* const cliffc_hashtable<TypeK, TypeV>::MATCH_ANY = new slot(false, NULL);
9
10 template<typename TypeK, typename TypeV>
11 slot* const cliffc_hashtable<TypeK, TypeV>::NO_MATCH_OLD = new slot(false, NULL);
12
13 template<typename TypeK, typename TypeV>
14 slot* const cliffc_hashtable<TypeK, TypeV>::TOMBPRIME = new slot(true, NULL);
15
16 template<typename TypeK, typename TypeV>
17 slot* const cliffc_hashtable<TypeK, TypeV>::TOMBSTONE = new slot(false, NULL);
18
19
20 class IntWrapper {
21         private:
22                 public:
23             int _val;
24
25                 IntWrapper(int val) : _val(val) {}
26
27                 IntWrapper() : _val(0) {}
28
29                 IntWrapper(IntWrapper& copy) : _val(copy._val) {}
30
31                 int get() {
32                         return _val;
33                 }
34
35                 int hashCode() {
36                         return _val;
37                 }
38                 
39                 bool operator==(const IntWrapper& rhs) {
40                         return false;
41                 }
42
43                 bool equals(const void *another) {
44                         if (another == NULL)
45                                 return false;
46                         IntWrapper *ptr =
47                                 (IntWrapper*) another;
48                         return ptr->_val == _val;
49                 }
50 };
51
52 cliffc_hashtable<IntWrapper, IntWrapper> *table;
53 IntWrapper *val1, *val2;
54
55 void threadA(void *arg) {
56         
57         IntWrapper *k1 = new IntWrapper(3), *k2 = new IntWrapper(2),
58                 *k3 = new IntWrapper(1024), *k4 = new IntWrapper(1025);
59         IntWrapper *v1 = new IntWrapper(1024), *v2 = new IntWrapper(1025),
60                 *v3 = new IntWrapper(73), *v4 = new IntWrapper(81);
61         
62         table->put(k1, v1);
63         table->put(k2, v2);
64         //table->put(k4, v3);
65         //table->put(v3, v3);
66         
67         val1 = table->get(k3);
68         if (val1 != NULL)
69                 model_print("val1: %d\n", val1->_val);
70         else
71                 model_print("val1: NULL\n");
72         //table->put(k3, v3);
73         
74 }
75
76 void threadB(void *arg) {
77         /*
78         IntWrapper *k1 = new IntWrapper(3), *k2 = new IntWrapper(5),
79                 *k3 = new IntWrapper(1024), *k4 = new IntWrapper(1025);
80         IntWrapper *v1 = new IntWrapper(1024), *v2 = new IntWrapper(1025),
81                 *v3 = new IntWrapper(73), *v4 = new IntWrapper(81);
82         table->put(k1, v3);
83         val1 = table->get(k2);
84         table->put(k2, v4);
85         val1 = table->get(k2);
86         */
87 }
88
89 void threadMain(void *arg) {
90         /*
91         for (int i = 0; i < 5; i++) {
92                 IntWrapper *k = new IntWrapper(i), *v = new IntWrapper(i * 2);
93                 table->put(k, v);
94         }
95         */
96         IntWrapper *k1 = new IntWrapper(3), *k2 = new IntWrapper(5),
97                 *k3 = new IntWrapper(1024), *k4 = new IntWrapper(1025);
98         IntWrapper *v1 = new IntWrapper(1024), *v2 = new IntWrapper(1025),
99                 *v3 = new IntWrapper(73), *v4 = new IntWrapper(81);
100         table->put(k3, v3);
101         //val1 = table->get(k2);
102 }
103
104 int user_main(int argc, char *argv[]) {
105         thrd_t t1, t2;
106         table = new cliffc_hashtable<IntWrapper, IntWrapper>(2);
107         val1 = NULL;
108         val2 = NULL;
109         //threadMain(NULL);
110
111         thrd_create(&t1, threadA, NULL);
112         thrd_create(&t2, threadB, NULL);
113         threadMain(NULL);
114
115         thrd_join(t1);
116         thrd_join(t2);
117         /*
118         if (val1 == NULL) {
119                 cout << "val1: NULL" << endl;
120         } else {
121                 cout << val1->get() << endl;
122         }
123         //MODEL_ASSERT(val1 == NULL || val1->get() == 2 || val1->get() == 81);
124         if (val2 == NULL) {
125                 cout << "val2: NULL" << endl;
126         } else {
127                 cout << val2->get() << endl;
128         }
129         */
130         return 0;
131 }
132