blob: 6a636a4c2429175fad9bca8d562f0ec7dc084ca0 [file] [log] [blame]
Andrew Scull18834872018-10-12 11:48:09 +01001/*
Andrew Walbran692b3252019-03-07 15:51:31 +00002 * Copyright 2018 The Hafnium Authors.
Andrew Scull18834872018-10-12 11:48:09 +01003 *
Andrew Walbrane959ec12020-06-17 15:01:09 +01004 * Use of this source code is governed by a BSD-style
5 * license that can be found in the LICENSE file or at
6 * https://opensource.org/licenses/BSD-3-Clause.
Andrew Scull18834872018-10-12 11:48:09 +01007 */
8
Andrew Scullfbc938a2018-08-20 14:09:28 +01009#pragma once
Wedson Almeida Filho3fcbcff2018-07-10 23:53:39 +010010
Andrew Scull18c78fc2018-08-20 12:57:41 +010011#include "hf/cpu.h"
Wedson Almeida Filho22d5eaa2018-12-16 00:38:49 +000012#include "hf/mpool.h"
Andrew Scull18c78fc2018-08-20 12:57:41 +010013#include "hf/vm.h"
Wedson Almeida Filho3fcbcff2018-07-10 23:53:39 +010014
Andrew Scull6d2db332018-10-10 15:28:17 +010015#include "vmapi/hf/call.h"
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010016#include "vmapi/hf/ffa.h"
Andrew Scull6d2db332018-10-10 15:28:17 +010017
Wedson Almeida Filho22d5eaa2018-12-16 00:38:49 +000018void api_init(struct mpool *ppool);
Andrew Walbran1f8d4872018-12-20 11:21:32 +000019void api_regs_state_saved(struct vcpu *vcpu);
Wedson Almeida Filhoea62e2e2019-01-09 19:14:59 +000020int64_t api_mailbox_writable_get(const struct vcpu *current);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010021int64_t api_mailbox_waiter_get(ffa_vm_id_t vm_id, const struct vcpu *current);
Andrew Walbranc1ad4ce2019-05-09 11:41:39 +010022int64_t api_debug_log(char c, struct vcpu *current);
Andrew Scull6bca35e2018-10-02 12:05:32 +010023
Andrew Scull33fecd32019-01-08 14:48:27 +000024struct vcpu *api_preempt(struct vcpu *current);
Andrew Scull33fecd32019-01-08 14:48:27 +000025struct vcpu *api_wait_for_interrupt(struct vcpu *current);
Andrew Walbran33645652019-04-15 12:29:31 +010026struct vcpu *api_vcpu_off(struct vcpu *current);
Andrew Scull9726c252019-01-23 13:44:19 +000027struct vcpu *api_abort(struct vcpu *current);
Andrew Walbran33645652019-04-15 12:29:31 +010028struct vcpu *api_wake_up(struct vcpu *current, struct vcpu *target_vcpu);
Andrew Walbran318f5732018-11-20 16:23:42 +000029
Manish Pandey35e452f2021-02-18 21:36:34 +000030int64_t api_interrupt_enable(uint32_t intid, bool enable,
31 enum interrupt_type type, struct vcpu *current);
Wedson Almeida Filhoc559d132019-01-09 19:33:40 +000032uint32_t api_interrupt_get(struct vcpu *current);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010033int64_t api_interrupt_inject(ffa_vm_id_t target_vm_id,
34 ffa_vcpu_index_t target_vcpu_idx, uint32_t intid,
Andrew Walbran42347a92019-05-09 13:59:03 +010035 struct vcpu *current, struct vcpu **next);
Jose Marinhoa1dfeda2019-02-27 16:46:03 +000036
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010037struct ffa_value api_ffa_msg_send(ffa_vm_id_t sender_vm_id,
38 ffa_vm_id_t receiver_vm_id, uint32_t size,
39 uint32_t attributes, struct vcpu *current,
40 struct vcpu **next);
41struct ffa_value api_ffa_msg_recv(bool block, struct vcpu *current,
42 struct vcpu **next);
43struct ffa_value api_ffa_rx_release(struct vcpu *current, struct vcpu **next);
Manish Pandeyd34f8892020-06-19 17:41:07 +010044struct ffa_value api_vm_configure_pages(
45 struct mm_stage1_locked mm_stage1_locked, struct vm_locked vm_locked,
46 ipaddr_t send, ipaddr_t recv, uint32_t page_count,
47 struct mpool *local_page_pool);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010048struct ffa_value api_ffa_rxtx_map(ipaddr_t send, ipaddr_t recv,
49 uint32_t page_count, struct vcpu *current,
50 struct vcpu **next);
Olivier Deprezee9d6a92019-11-26 09:14:11 +000051struct ffa_value api_yield(struct vcpu *current, struct vcpu **next);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010052struct ffa_value api_ffa_version(uint32_t requested_version);
Fuad Tabbae4efcc32020-07-16 15:37:27 +010053struct ffa_value api_ffa_partition_info_get(struct vcpu *current,
54 const struct ffa_uuid *uuid);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010055struct ffa_value api_ffa_id_get(const struct vcpu *current);
56struct ffa_value api_ffa_features(uint32_t function_id);
57struct ffa_value api_ffa_run(ffa_vm_id_t vm_id, ffa_vcpu_index_t vcpu_idx,
58 const struct vcpu *current, struct vcpu **next);
59struct ffa_value api_ffa_mem_send(uint32_t share_func, uint32_t length,
60 uint32_t fragment_length, ipaddr_t address,
Andrew Walbran1a86aa92020-05-15 17:22:28 +010061 uint32_t page_count, struct vcpu *current);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010062struct ffa_value api_ffa_mem_retrieve_req(uint32_t length,
63 uint32_t fragment_length,
64 ipaddr_t address, uint32_t page_count,
65 struct vcpu *current);
66struct ffa_value api_ffa_mem_relinquish(struct vcpu *current);
67struct ffa_value api_ffa_mem_reclaim(ffa_memory_handle_t handle,
68 ffa_memory_region_flags_t flags,
69 struct vcpu *current);
Andrew Walbranca808b12020-05-15 17:22:28 +010070struct ffa_value api_ffa_mem_frag_rx(ffa_memory_handle_t handle,
71 uint32_t fragment_offset,
72 ffa_vm_id_t sender_vm_id,
73 struct vcpu *current);
74struct ffa_value api_ffa_mem_frag_tx(ffa_memory_handle_t handle,
75 uint32_t fragment_length,
76 ffa_vm_id_t sender_vm_id,
77 struct vcpu *current);
Olivier Deprezee9d6a92019-11-26 09:14:11 +000078struct ffa_value api_ffa_msg_send_direct_req(ffa_vm_id_t sender_vm_id,
79 ffa_vm_id_t receiver_vm_id,
80 struct ffa_value args,
81 struct vcpu *current,
82 struct vcpu **next);
83struct ffa_value api_ffa_msg_send_direct_resp(ffa_vm_id_t sender_vm_id,
84 ffa_vm_id_t receiver_vm_id,
85 struct ffa_value args,
86 struct vcpu *current,
87 struct vcpu **next);
Max Shvetsov40108e72020-08-27 12:39:50 +010088struct ffa_value api_ffa_secondary_ep_register(ipaddr_t entry_point,
89 struct vcpu *current);