diff options
author | Jason Ekstrand <[email protected]> | 2017-02-20 10:37:34 -0800 |
---|---|---|
committer | Jason Ekstrand <[email protected]> | 2017-02-21 12:26:35 -0800 |
commit | f408971deb7821cc140f1d373a104c2e1cb24eeb (patch) | |
tree | bde0c4fe60303bf35b580a3835e9bc4ae1bd7b9c /src/intel/vulkan/anv_device.c | |
parent | 16b187c8bb5ed10c667326346711c89ff7420ab2 (diff) |
anv: Pull all clflushing into a clflush_range helper
All this cache line address calculation stuff is tricky. Let's not
duplicate it more places than we have to.
Reviewed-by: Lionel Landwerlin <[email protected]>
Diffstat (limited to 'src/intel/vulkan/anv_device.c')
-rw-r--r-- | src/intel/vulkan/anv_device.c | 15 |
1 files changed, 4 insertions, 11 deletions
diff --git a/src/intel/vulkan/anv_device.c b/src/intel/vulkan/anv_device.c index f14c1abc795..f52b42a542f 100644 --- a/src/intel/vulkan/anv_device.c +++ b/src/intel/vulkan/anv_device.c @@ -1486,18 +1486,11 @@ clflush_mapped_ranges(struct anv_device *device, { for (uint32_t i = 0; i < count; i++) { ANV_FROM_HANDLE(anv_device_memory, mem, ranges[i].memory); - void *p = mem->map + (ranges[i].offset & ~CACHELINE_MASK); - void *end; + if (ranges[i].offset >= mem->map_size) + continue; - if (ranges[i].offset + ranges[i].size > mem->map_size) - end = mem->map + mem->map_size; - else - end = mem->map + ranges[i].offset + ranges[i].size; - - while (p < end) { - __builtin_ia32_clflush(p); - p += CACHELINE_SIZE; - } + anv_clflush_range(mem->map + ranges[i].offset, + MIN2(ranges[i].size, mem->map_size - ranges[i].offset)); } } |