Commit aa5beec3 authored by Eric Anholt's avatar Eric Anholt

drm/v3d: Invalidate the caches from the outside in.

This would be a fairly obscure race, but let's make sure we don't ever
lose it.
Signed-off-by: default avatarEric Anholt <eric@anholt.net>
Link: https://patchwork.freedesktop.org/patch/msgid/20181203222438.25417-6-eric@anholt.netReviewed-by: default avatarDave Emett <david.emett@broadcom.com>
parent 7b9d2fe4
...@@ -171,11 +171,15 @@ v3d_invalidate_slices(struct v3d_dev *v3d, int core) ...@@ -171,11 +171,15 @@ v3d_invalidate_slices(struct v3d_dev *v3d, int core)
void void
v3d_invalidate_caches(struct v3d_dev *v3d) v3d_invalidate_caches(struct v3d_dev *v3d)
{ {
/* Invalidate the caches from the outside in. That way if
* another CL's concurrent use of nearby memory were to pull
* an invalidated cacheline back in, we wouldn't leave stale
* data in the inner cache.
*/
v3d_flush_l3(v3d); v3d_flush_l3(v3d);
v3d_invalidate_l2c(v3d, 0); v3d_invalidate_l2c(v3d, 0);
v3d_invalidate_slices(v3d, 0);
v3d_flush_l2t(v3d, 0); v3d_flush_l2t(v3d, 0);
v3d_invalidate_slices(v3d, 0);
} }
static void static void
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment