unsigned long val;
 
        if (mem_cgroup_is_root(memcg)) {
-               mem_cgroup_flush_stats();
+               /*
+                * We can reach here from irq context through:
+                * uncharge_batch()
+                * |--memcg_check_events()
+                *    |--mem_cgroup_threshold()
+                *       |--__mem_cgroup_threshold()
+                *          |--mem_cgroup_usage
+                *
+                * rstat flushing is an expensive operation that should not be
+                * done from irq context; use stale stats in this case.
+                * Arguably, usage threshold events are not reliable on the root
+                * memcg anyway since its usage is ill-defined.
+                */
+               if (in_task())
+                       mem_cgroup_flush_stats();
                val = memcg_page_state(memcg, NR_FILE_PAGES) +
                        memcg_page_state(memcg, NR_ANON_MAPPED);
                if (swap)