update
[lttv.git] / markers-test / test-mark-speed-local.c
index 254d882f6ecce55d54daebed1b03b15b0a346b08..71cd6b6fc0d0c6a39a31351e8ebb0b5cd4c37713 100644 (file)
@@ -59,17 +59,22 @@ static void noinline test2(const struct marker *mdata,
                }                                                       \
        } while (0)
 
-       //asm volatile ("");
 struct proc_dir_entry *pentry = NULL;
 
+int temp __cacheline_aligned = 10;
+int temp2 __cacheline_aligned = 10;
+
 static inline void test(unsigned long arg, unsigned long arg2)
 {
 #ifdef CACHEFLUSH
        wbinvd();
 #endif
+       temp = (temp + 60) << 10;
        //asm volatile ("");
        //__my_trace_mark(1, kernel_debug_test, NULL, "%d %d %ld %ld", 2, current->pid, arg, arg2);
+       barrier();
        test2(NULL, NULL, 2, 10, arg, arg2);
+       barrier();      // make sure the compiler does not optimize marker conditions away!
        //__my_trace_mark(0, kernel_debug_test, NULL, "%d %d %ld %ld", 2, current->pid, arg, arg2);
 }
 
@@ -85,6 +90,15 @@ static int my_open(struct inode *inode, struct file *file)
        rdtsc_barrier();
        for(i=0; i<2000; i++) {
                test(i, i);
+               test(i, i);
+               test(i, i);
+               test(i, i);
+               test(i, i);
+               test(i, i);
+               test(i, i);
+               test(i, i);
+               test(i, i);
+               test(i, i);
        }
        rdtsc_barrier();
        cycles2 = get_cycles();
This page took 0.023245 seconds and 4 git commands to generate.