summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/nvgpu/Makefile3
-rw-r--r--drivers/gpu/nvgpu/include/nvgpu/barrier.h9
-rw-r--r--drivers/gpu/nvgpu/include/nvgpu/linux/barrier.h2
3 files changed, 14 insertions, 0 deletions
diff --git a/drivers/gpu/nvgpu/Makefile b/drivers/gpu/nvgpu/Makefile
index 680a9f4f..d70c44e8 100644
--- a/drivers/gpu/nvgpu/Makefile
+++ b/drivers/gpu/nvgpu/Makefile
@@ -14,6 +14,9 @@ ifeq ($(VERSION),4)
14ccflags-y += -Wextra -Wno-unused-parameter -Wno-missing-field-initializers 14ccflags-y += -Wextra -Wno-unused-parameter -Wno-missing-field-initializers
15endif 15endif
16 16
17# Turn off when this is fixed upstream, if ever.
18ccflags-y += -D__NVGPU_PREVENT_UNTRUSTED_SPECULATION
19
17obj-$(CONFIG_GK20A) := nvgpu.o 20obj-$(CONFIG_GK20A) := nvgpu.o
18 21
19nvgpu-y := \ 22nvgpu-y := \
diff --git a/drivers/gpu/nvgpu/include/nvgpu/barrier.h b/drivers/gpu/nvgpu/include/nvgpu/barrier.h
index 01bd3023..03a14a99 100644
--- a/drivers/gpu/nvgpu/include/nvgpu/barrier.h
+++ b/drivers/gpu/nvgpu/include/nvgpu/barrier.h
@@ -47,4 +47,13 @@
47 47
48#define NV_ACCESS_ONCE(x) __NV_ACCESS_ONCE(x) 48#define NV_ACCESS_ONCE(x) __NV_ACCESS_ONCE(x)
49 49
50/*
51 * Sometimes we want to prevent speculation.
52 */
53#ifdef __NVGPU_PREVENT_UNTRUSTED_SPECULATION
54#define nvgpu_speculation_barrier() __nvgpu_speculation_barrier()
55#else
56#define nvgpu_speculation_barrier()
57#endif
58
50#endif /* __NVGPU_BARRIER_H__ */ 59#endif /* __NVGPU_BARRIER_H__ */
diff --git a/drivers/gpu/nvgpu/include/nvgpu/linux/barrier.h b/drivers/gpu/nvgpu/include/nvgpu/linux/barrier.h
index b20f9462..ef867c44 100644
--- a/drivers/gpu/nvgpu/include/nvgpu/linux/barrier.h
+++ b/drivers/gpu/nvgpu/include/nvgpu/linux/barrier.h
@@ -32,4 +32,6 @@
32 32
33#define __NV_ACCESS_ONCE(x) ACCESS_ONCE(x) 33#define __NV_ACCESS_ONCE(x) ACCESS_ONCE(x)
34 34
35#define __nvgpu_speculation_barrier() speculation_barrier()
36
35#endif /* __NVGPU_BARRIER_LINUX_H__ */ 37#endif /* __NVGPU_BARRIER_LINUX_H__ */