This prevents speculative reading of the statistics before the
completion flag.
From: Neil Turton <nturton@solarflare.com>
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
 
        /* Wait for transfer to complete */
        for (i = 0; i < 400; i++) {
-               if (*(volatile u32 *)dma_done == FALCON_STATS_DONE)
+               if (*(volatile u32 *)dma_done == FALCON_STATS_DONE) {
+                       rmb(); /* Ensure the stats are valid. */
                        return 0;
+               }
                udelay(10);
        }