mirror of
https://github.com/riscv-software-src/opensbi.git
synced 2025-08-24 15:31:22 +01:00

Currently, there is no provision for tracking multiple IPIs sent to a single hart at the same time by different harts. Use a fifo manage the outstanding requests. While dequeueing, read all the entries once, because we have only 1 bit to track the type of IPI. Once the queue is full, busy wait until the there is space available in queue. This is not the most elegant approach. It should be changed in favor of a wakeup event once available in opensbi. Signed-off-by: Atish Patra <atish.patra@wdc.com>
53 lines
1.1 KiB
C
53 lines
1.1 KiB
C
/*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*
|
|
* Copyright (c) 2019 Western Digital Corporation or its affiliates.
|
|
*
|
|
* Authors:
|
|
* Anup Patel <anup.patel@wdc.com>
|
|
*/
|
|
|
|
#ifndef __SBI_IPI_H__
|
|
#define __SBI_IPI_H__
|
|
|
|
#include <sbi/sbi_types.h>
|
|
|
|
#define SBI_IPI_EVENT_SOFT 0x1
|
|
#define SBI_IPI_EVENT_FENCE_I 0x2
|
|
#define SBI_IPI_EVENT_SFENCE_VMA 0x4
|
|
#define SBI_IPI_EVENT_SFENCE_VMA_ASID 0x8
|
|
#define SBI_IPI_EVENT_HALT 0x10
|
|
|
|
#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_ipi_data {
|
|
unsigned long ipi_type;
|
|
};
|
|
|
|
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_ipi_send_many(struct sbi_scratch *scratch,
|
|
ulong *pmask, u32 event, void *data);
|
|
|
|
void sbi_ipi_clear_smode(struct sbi_scratch *scratch);
|
|
|
|
void sbi_ipi_process(struct sbi_scratch *scratch);
|
|
|
|
int sbi_ipi_init(struct sbi_scratch *scratch, bool cold_boot);
|
|
|
|
#endif
|