You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
208 lines
6.1 KiB
208 lines
6.1 KiB
/* SPDX-License-Identifier: BSD-3-Clause */
|
|
/*
|
|
* Copyright (c) 2015-2019, Arm Limited and Contributors. All rights reserved.
|
|
* Copyright (c) 2019, Linaro Limited
|
|
*/
|
|
|
|
#ifndef SCMI_MSG_H
|
|
#define SCMI_MSG_H
|
|
|
|
#include <stdbool.h>
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
/* Minimum size expected for SMT based shared memory message buffers */
|
|
#define SMT_BUF_SLOT_SIZE 128U
|
|
|
|
/* A channel abstract a communication path between agent and server */
|
|
struct scmi_msg_channel;
|
|
|
|
/*
|
|
* struct scmi_msg_channel - Shared memory buffer for a agent-to-server channel
|
|
*
|
|
* @shm_addr: Address of the shared memory for the SCMI channel
|
|
* @shm_size: Byte size of the shared memory for the SCMI channel
|
|
* @busy: True when channel is busy, flase when channel is free
|
|
* @agent_name: Agent name, SCMI protocol exposes 16 bytes max, or NULL
|
|
*/
|
|
struct scmi_msg_channel {
|
|
uintptr_t shm_addr;
|
|
size_t shm_size;
|
|
bool busy;
|
|
const char *agent_name;
|
|
};
|
|
|
|
/*
|
|
* Initialize SMT memory buffer, called by platform at init for each
|
|
* agent channel using the SMT header format.
|
|
*
|
|
* @chan: Pointer to the channel shared memory to be initialized
|
|
*/
|
|
void scmi_smt_init_agent_channel(struct scmi_msg_channel *chan);
|
|
|
|
/*
|
|
* Process SMT formatted message in a fastcall SMC execution context.
|
|
* Called by platform on SMC entry. When returning, output message is
|
|
* available in shared memory for agent to read the response.
|
|
*
|
|
* @agent_id: SCMI agent ID the SMT belongs to
|
|
*/
|
|
void scmi_smt_fastcall_smc_entry(unsigned int agent_id);
|
|
|
|
/*
|
|
* Process SMT formatted message in a secure interrupt execution context.
|
|
* Called by platform interrupt handler. When returning, output message is
|
|
* available in shared memory for agent to read the response.
|
|
*
|
|
* @agent_id: SCMI agent ID the SMT belongs to
|
|
*/
|
|
void scmi_smt_interrupt_entry(unsigned int agent_id);
|
|
|
|
/* Platform callback functions */
|
|
|
|
/*
|
|
* Return the SCMI channel related to an agent
|
|
* @agent_id: SCMI agent ID
|
|
* Return a pointer to channel on success, NULL otherwise
|
|
*/
|
|
struct scmi_msg_channel *plat_scmi_get_channel(unsigned int agent_id);
|
|
|
|
/*
|
|
* Return how many SCMI protocols supported by the platform
|
|
* According to the SCMI specification, this function does not target
|
|
* a specific agent ID and shall return all platform known capabilities.
|
|
*/
|
|
size_t plat_scmi_protocol_count(void);
|
|
|
|
/*
|
|
* Get the count and list of SCMI protocols (but base) supported for an agent
|
|
*
|
|
* @agent_id: SCMI agent ID
|
|
* Return a pointer to a null terminated array supported protocol IDs.
|
|
*/
|
|
const uint8_t *plat_scmi_protocol_list(unsigned int agent_id);
|
|
|
|
/* Get the name of the SCMI vendor for the platform */
|
|
const char *plat_scmi_vendor_name(void);
|
|
|
|
/* Get the name of the SCMI sub-vendor for the platform */
|
|
const char *plat_scmi_sub_vendor_name(void);
|
|
|
|
/* Handlers for SCMI Clock protocol services */
|
|
|
|
/*
|
|
* Return number of clock controllers for an agent
|
|
* @agent_id: SCMI agent ID
|
|
* Return number of clock controllers
|
|
*/
|
|
size_t plat_scmi_clock_count(unsigned int agent_id);
|
|
|
|
/*
|
|
* Get clock controller string ID (aka name)
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI clock ID
|
|
* Return pointer to name or NULL
|
|
*/
|
|
const char *plat_scmi_clock_get_name(unsigned int agent_id,
|
|
unsigned int scmi_id);
|
|
|
|
/*
|
|
* Get clock possible rate as an array of frequencies in Hertz.
|
|
*
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI clock ID
|
|
* @rates: If NULL, function returns, else output rates array
|
|
* @nb_elts: Array size of @rates.
|
|
* Return an SCMI compliant error code
|
|
*/
|
|
int32_t plat_scmi_clock_rates_array(unsigned int agent_id, unsigned int scmi_id,
|
|
unsigned long *rates, size_t *nb_elts);
|
|
|
|
/*
|
|
* Get clock possible rate as range with regular steps in Hertz
|
|
*
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI clock ID
|
|
* @min_max_step: 3 cell array for min, max and step rate data
|
|
* Return an SCMI compliant error code
|
|
*/
|
|
int32_t plat_scmi_clock_rates_by_step(unsigned int agent_id,
|
|
unsigned int scmi_id,
|
|
unsigned long *min_max_step);
|
|
|
|
/*
|
|
* Get clock rate in Hertz
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI clock ID
|
|
* Return clock rate or 0 if not supported
|
|
*/
|
|
unsigned long plat_scmi_clock_get_rate(unsigned int agent_id,
|
|
unsigned int scmi_id);
|
|
|
|
/*
|
|
* Set clock rate in Hertz
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI clock ID
|
|
* @rate: Target clock frequency in Hertz
|
|
* Return a compliant SCMI error code
|
|
*/
|
|
int32_t plat_scmi_clock_set_rate(unsigned int agent_id, unsigned int scmi_id,
|
|
unsigned long rate);
|
|
|
|
/*
|
|
* Get clock state (enabled or disabled)
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI clock ID
|
|
* Return 1 if clock is enabled, 0 if disables, or a negative SCMI error code
|
|
*/
|
|
int32_t plat_scmi_clock_get_state(unsigned int agent_id, unsigned int scmi_id);
|
|
|
|
/*
|
|
* Get clock state (enabled or disabled)
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI clock ID
|
|
* @enable_not_disable: Enable clock if true, disable clock otherwise
|
|
* Return a compliant SCMI error code
|
|
*/
|
|
int32_t plat_scmi_clock_set_state(unsigned int agent_id, unsigned int scmi_id,
|
|
bool enable_not_disable);
|
|
|
|
/* Handlers for SCMI Reset Domain protocol services */
|
|
|
|
/*
|
|
* Return number of reset domains for the agent
|
|
* @agent_id: SCMI agent ID
|
|
* Return number of reset domains
|
|
*/
|
|
size_t plat_scmi_rstd_count(unsigned int agent_id);
|
|
|
|
/*
|
|
* Get reset domain string ID (aka name)
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI reset domain ID
|
|
* Return pointer to name or NULL
|
|
*/
|
|
const char *plat_scmi_rstd_get_name(unsigned int agent_id, unsigned int scmi_id);
|
|
|
|
/*
|
|
* Perform a reset cycle on a target reset domain
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI reset domain ID
|
|
* @state: Target reset state (see SCMI specification, 0 means context loss)
|
|
* Return a compliant SCMI error code
|
|
*/
|
|
int32_t plat_scmi_rstd_autonomous(unsigned int agent_id, unsigned int scmi_id,
|
|
unsigned int state);
|
|
|
|
/*
|
|
* Assert or deassert target reset domain
|
|
* @agent_id: SCMI agent ID
|
|
* @scmi_id: SCMI reset domain ID
|
|
* @assert_not_deassert: Assert domain if true, otherwise deassert domain
|
|
* Return a compliant SCMI error code
|
|
*/
|
|
int32_t plat_scmi_rstd_set_state(unsigned int agent_id, unsigned int scmi_id,
|
|
bool assert_not_deassert);
|
|
|
|
#endif /* SCMI_MSG_H */
|