restore_math(current->thread.regs);
 
                /*
-                * The copy-paste buffer can only store into foreign real
-                * addresses, so unprivileged processes can not see the
-                * data or use it in any way unless they have foreign real
-                * mappings. If the new process has the foreign real address
-                * mappings, we must issue a cp_abort to clear any state and
-                * prevent snooping, corruption or a covert channel.
+                * On POWER9 the copy-paste buffer can only paste into
+                * foreign real addresses, so unprivileged processes can not
+                * see the data or use it in any way unless they have
+                * foreign real mappings. If the new process has the foreign
+                * real address mappings, we must issue a cp_abort to clear
+                * any state and prevent snooping, corruption or a covert
+                * channel. ISA v3.1 supports paste into local memory.
                 */
                if (current->mm &&
-                       atomic_read(¤t->mm->context.vas_windows))
+                       (cpu_has_feature(CPU_FTR_ARCH_31) ||
+                       atomic_read(¤t->mm->context.vas_windows)))
                        asm volatile(PPC_CP_ABORT);
        }
 #endif /* CONFIG_PPC_BOOK3S_64 */
 
         */
        asm volatile("eieio; tlbsync; ptesync");
 
+       /*
+        * cp_abort is required if the processor supports local copy-paste
+        * to clear the copy buffer that was under control of the guest.
+        */
+       if (cpu_has_feature(CPU_FTR_ARCH_31))
+               asm volatile(PPC_CP_ABORT);
+
        mtspr(SPRN_LPID, vcpu->kvm->arch.host_lpid);    /* restore host LPID */
        isync();
 
 
 2:
 #endif /* CONFIG_PPC_RADIX_MMU */
 
+       /*
+        * cp_abort is required if the processor supports local copy-paste
+        * to clear the copy buffer that was under control of the guest.
+        */
+BEGIN_FTR_SECTION
+       PPC_CP_ABORT
+END_FTR_SECTION_IFSET(CPU_FTR_ARCH_31)
+
        /*
         * POWER7/POWER8 guest -> host partition switch code.
         * We don't have to lock against tlbies but we do