162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (C) 2022 Ventana Micro Systems Inc. 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#include <linux/export.h> 762306a36Sopenharmony_ci#include <linux/libnvdimm.h> 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#include <asm/cacheflush.h> 1062306a36Sopenharmony_ci#include <asm/dma-noncoherent.h> 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_civoid arch_wb_cache_pmem(void *addr, size_t size) 1362306a36Sopenharmony_ci{ 1462306a36Sopenharmony_ci#ifdef CONFIG_RISCV_NONSTANDARD_CACHE_OPS 1562306a36Sopenharmony_ci if (unlikely(noncoherent_cache_ops.wback)) { 1662306a36Sopenharmony_ci noncoherent_cache_ops.wback(virt_to_phys(addr), size); 1762306a36Sopenharmony_ci return; 1862306a36Sopenharmony_ci } 1962306a36Sopenharmony_ci#endif 2062306a36Sopenharmony_ci ALT_CMO_OP(clean, addr, size, riscv_cbom_block_size); 2162306a36Sopenharmony_ci} 2262306a36Sopenharmony_ciEXPORT_SYMBOL_GPL(arch_wb_cache_pmem); 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_civoid arch_invalidate_pmem(void *addr, size_t size) 2562306a36Sopenharmony_ci{ 2662306a36Sopenharmony_ci#ifdef CONFIG_RISCV_NONSTANDARD_CACHE_OPS 2762306a36Sopenharmony_ci if (unlikely(noncoherent_cache_ops.inv)) { 2862306a36Sopenharmony_ci noncoherent_cache_ops.inv(virt_to_phys(addr), size); 2962306a36Sopenharmony_ci return; 3062306a36Sopenharmony_ci } 3162306a36Sopenharmony_ci#endif 3262306a36Sopenharmony_ci ALT_CMO_OP(inval, addr, size, riscv_cbom_block_size); 3362306a36Sopenharmony_ci} 3462306a36Sopenharmony_ciEXPORT_SYMBOL_GPL(arch_invalidate_pmem); 35