|
@@ -162,6 +162,33 @@ void do_rfi_flush_fixups(enum l1d_flush_type types)
|
|
|
(types & L1D_FLUSH_MTTRIG) ? "mttrig type"
|
|
|
: "unknown");
|
|
|
}
|
|
|
+
|
|
|
+void do_barrier_nospec_fixups(bool enable)
|
|
|
+{
|
|
|
+ unsigned int instr, *dest;
|
|
|
+ long *start, *end;
|
|
|
+ int i;
|
|
|
+
|
|
|
+ start = PTRRELOC(&__start___barrier_nospec_fixup),
|
|
|
+ end = PTRRELOC(&__stop___barrier_nospec_fixup);
|
|
|
+
|
|
|
+ instr = 0x60000000; /* nop */
|
|
|
+
|
|
|
+ if (enable) {
|
|
|
+ pr_info("barrier-nospec: using ORI speculation barrier\n");
|
|
|
+ instr = 0x63ff0000; /* ori 31,31,0 speculation barrier */
|
|
|
+ }
|
|
|
+
|
|
|
+ for (i = 0; start < end; start++, i++) {
|
|
|
+ dest = (void *)start + *start;
|
|
|
+
|
|
|
+ pr_devel("patching dest %lx\n", (unsigned long)dest);
|
|
|
+ patch_instruction(dest, instr);
|
|
|
+ }
|
|
|
+
|
|
|
+ printk(KERN_DEBUG "barrier-nospec: patched %d locations\n", i);
|
|
|
+}
|
|
|
+
|
|
|
#endif /* CONFIG_PPC_BOOK3S_64 */
|
|
|
|
|
|
void do_lwsync_fixups(unsigned long value, void *fixup_start, void *fixup_end)
|