mirror of
https://source.denx.de/u-boot/u-boot.git
synced 2025-10-23 21:41:23 +02:00
Add a wait option to smp_call_function() to wait for the secondary harts to acknowledge the call-function request. The request is considered to be acknowledged once each secondary hart has cleared the corresponding IPI. As part of the call-function request, the secondary harts invalidate the instruction cache after clearing the IPI. This adds a delay between acknowledgment (clear IPI) and fulfillment (call function) of the request. We want to use the acknowledgment to be able to judge when the request has been completed. Remove the delay by clearing the IPI after cache invalidation and just before calling the function from the request. Signed-off-by: Lukas Auer <lukas.auer@aisec.fraunhofer.de> Reviewed-by: Rick Chen <rick@andestech.com> Tested-by: Rick Chen <rick@andestech.com> Reviewed-by: Anup Patel <anup.patel@wdc.com>
55 lines
1.4 KiB
C
55 lines
1.4 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (C) 2019 Fraunhofer AISEC,
|
|
* Lukas Auer <lukas.auer@aisec.fraunhofer.de>
|
|
*/
|
|
|
|
#ifndef _ASM_RISCV_SMP_H
|
|
#define _ASM_RISCV_SMP_H
|
|
|
|
/**
|
|
* struct ipi_data - Inter-processor interrupt (IPI) data structure
|
|
*
|
|
* IPIs are used for SMP support to communicate to other harts what function to
|
|
* call. Functions are in the form
|
|
* void (*addr)(ulong hart, ulong arg0, ulong arg1).
|
|
*
|
|
* The function address and the two arguments, arg0 and arg1, are stored in the
|
|
* IPI data structure. The hart ID is inserted by the hart handling the IPI and
|
|
* calling the function.
|
|
*
|
|
* @addr: Address of function
|
|
* @arg0: First argument of function
|
|
* @arg1: Second argument of function
|
|
*/
|
|
struct ipi_data {
|
|
ulong addr;
|
|
ulong arg0;
|
|
ulong arg1;
|
|
};
|
|
|
|
/**
|
|
* handle_ipi() - interrupt handler for software interrupts
|
|
*
|
|
* The IPI interrupt handler must be called to handle software interrupts. It
|
|
* calls the function specified in the hart's IPI data structure.
|
|
*
|
|
* @hart: Hart ID of the current hart
|
|
*/
|
|
void handle_ipi(ulong hart);
|
|
|
|
/**
|
|
* smp_call_function() - Call a function on all other harts
|
|
*
|
|
* Send IPIs with the specified function call to all harts.
|
|
*
|
|
* @addr: Address of function
|
|
* @arg0: First argument of function
|
|
* @arg1: Second argument of function
|
|
* @wait: Wait for harts to acknowledge request
|
|
* @return 0 if OK, -ve on error
|
|
*/
|
|
int smp_call_function(ulong addr, ulong arg0, ulong arg1, int wait);
|
|
|
|
#endif
|