/* * SPDX-License-Identifier: BSD-2-Clause * * Copyright (c) 2019 Western Digital Corporation or its affiliates. * * Authors: * Atish Patra * Anup Patel */ #ifndef __SBI_TLB_H__ #define __SBI_TLB_H__ #include /* clang-format off */ #define SBI_TLB_FLUSH_ALL ((unsigned long)-1) #define SBI_TLB_FLUSH_MAX_SIZE (1UL << 30) /* clang-format on */ #define SBI_TLB_FIFO_NUM_ENTRIES 4 enum sbi_tlb_info_types { SBI_TLB_FLUSH_VMA, SBI_TLB_FLUSH_VMA_ASID, SBI_TLB_FLUSH_VMA_VMID }; struct sbi_scratch; struct sbi_tlb_info { unsigned long start; unsigned long size; unsigned long asid; unsigned long type; }; #define SBI_TLB_INFO_SIZE sizeof(struct sbi_tlb_info) int sbi_tlb_fifo_update(struct sbi_scratch *scratch, u32 event, void *data); void sbi_tlb_fifo_process(struct sbi_scratch *scratch, u32 event); int sbi_tlb_fifo_init(struct sbi_scratch *scratch, bool cold_boot); #endif