update
[lttv.git] / markers-test / test-mark-speed-local.c
index 5bcbccb7b2ee1ea9c892142f75e5001628eec9da..552afcea23f84c2e074db9c643b7faa27978392c 100644 (file)
 #include <asm/ptrace.h>
 #include <asm/system.h>
 
+static void pmc_flush_cache(void)
+  {
+    /* write back and invalidate cache (a serializing instruction) */
+
+    __asm__ __volatile__ ( "wbinvd" : : : "memory" );
+
+    /* The wbinvd instruction does not wait for the external caches
+     * to be flushed, but only requests that it be done.  The loop
+     * is to be sure that enough time has elapsed, but the compiler
+     * might simplify or even remove it.  The loop bound is for a
+     * 512 KB L2 cache.  On a Pentium Pro/II/III, the loop uses
+     * 2 cycles per iteration.
+     *
+     * Does wbinvd also cause the TLB to be flushed?
+     * A comment in mtrr.c suggests that it does.
+     */
+    { register int i; for (i = 0; i < 512*1024; i++) { } }
+  }
+
+
 static void noinline test2(const struct marker *mdata,
         void *call_private, ...)
 {
@@ -68,7 +88,7 @@ char temp5[8192];
 static inline void test(unsigned long arg, unsigned long arg2)
 {
 #ifdef CACHEFLUSH
-       wbinvd();
+       pmc_flush_cache();
 #endif
        temp[2] = (temp[0] + 60) << 10;
        temp[3] = (temp[2] + 60) << 10;
@@ -90,7 +110,7 @@ static int my_open(struct inode *inode, struct file *file)
 
        local_irq_save(flags);
 #ifdef CACHEFLUSH
-       wbinvd();       /* initial write back, without cycle count */
+       pmc_flush_cache();      /* initial write back, without cycle count */
        msleep(20);     /* wait for L2 flush */
 #endif
        rdtsc_barrier();
This page took 0.024113 seconds and 4 git commands to generate.