| // SPDX-License-Identifier: GPL-2.0 |
| /* |
| * Copyright (C) 2022 Ventana Micro Systems Inc. |
| */ |
| |
| #include <linux/export.h> |
| #include <linux/libnvdimm.h> |
| |
| #include <asm/cacheflush.h> |
| #include <asm/dma-noncoherent.h> |
| |
| void arch_wb_cache_pmem(void *addr, size_t size) |
| { |
| #ifdef CONFIG_RISCV_NONSTANDARD_CACHE_OPS |
| if (unlikely(noncoherent_cache_ops.wback)) { |
| noncoherent_cache_ops.wback(virt_to_phys(addr), size); |
| return; |
| } |
| #endif |
| ALT_CMO_OP(CLEAN, addr, size, riscv_cbom_block_size); |
| } |
| EXPORT_SYMBOL_GPL(arch_wb_cache_pmem); |
| |
| void arch_invalidate_pmem(void *addr, size_t size) |
| { |
| #ifdef CONFIG_RISCV_NONSTANDARD_CACHE_OPS |
| if (unlikely(noncoherent_cache_ops.inv)) { |
| noncoherent_cache_ops.inv(virt_to_phys(addr), size); |
| return; |
| } |
| #endif |
| ALT_CMO_OP(INVAL, addr, size, riscv_cbom_block_size); |
| } |
| EXPORT_SYMBOL_GPL(arch_invalidate_pmem); |