| /* SPDX-License-Identifier: GPL-2.0 */ |
| #include <asm/compiler.h> |
| /* ECC atomic, DMA, SMP and interrupt safe scrub function */ |
| static inline void edac_atomic_scrub(void *va, u32 size) |
| unsigned long *virt_addr = va; |
| for (i = 0; i < size / sizeof(unsigned long); i++) { |
| * Very carefully read and write to memory atomically |
| * so we are interrupt, DMA and SMP safe. |
| * Intel: asm("lock; addl $0, %0"::"m"(*virt_addr)); |
| "1: ll %0, %1 # edac_atomic_scrub \n" |
| : "=&r" (temp), "=" GCC_OFF_SMALL_ASM() (*virt_addr) |
| : GCC_OFF_SMALL_ASM() (*virt_addr)); |