blob: 3e6614776a8282ac6d8510684dff43b5084896f0 [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"
Karl Meakin6f1f1212024-07-16 10:18:16 +010013#include "hf/vcpu.h"
Andrew Scull18c78fc2018-08-20 12:57:41 +010014#include "hf/vm.h"
Wedson Almeida Filho3fcbcff2018-07-10 23:53:39 +010015
Andrew Scull6d2db332018-10-10 15:28:17 +010016#include "vmapi/hf/call.h"
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010017#include "vmapi/hf/ffa.h"
Andrew Scull6d2db332018-10-10 15:28:17 +010018
J-Alvesbd32c972024-02-02 16:20:04 +000019static inline struct ffa_value api_ffa_interrupt_return(uint32_t id)
20{
21 return (struct ffa_value){.func = FFA_INTERRUPT_32, .arg2 = id};
22}
23
Wedson Almeida Filho22d5eaa2018-12-16 00:38:49 +000024void api_init(struct mpool *ppool);
Madhukar Pappireddyb11e0d12021-08-02 19:44:35 -050025struct vcpu *api_ffa_get_vm_vcpu(struct vm *vm, struct vcpu *current);
Andrew Walbran1f8d4872018-12-20 11:21:32 +000026void api_regs_state_saved(struct vcpu *vcpu);
Wedson Almeida Filhoea62e2e2019-01-09 19:14:59 +000027int64_t api_mailbox_writable_get(const struct vcpu *current);
J-Alves19e20cf2023-08-02 12:48:55 +010028int64_t api_mailbox_waiter_get(ffa_id_t vm_id, const struct vcpu *current);
Madhukar Pappireddybd10e572023-03-06 16:39:49 -060029struct vcpu *api_switch_to_vm(struct vcpu_locked current_locked,
30 struct ffa_value to_ret,
J-Alves19e20cf2023-08-02 12:48:55 +010031 enum vcpu_state vcpu_state, ffa_id_t to_id);
Madhukar Pappireddybd10e572023-03-06 16:39:49 -060032struct vcpu *api_switch_to_primary(struct vcpu_locked current_locked,
J-Alves27b71962022-12-12 15:29:58 +000033 struct ffa_value primary_ret,
34 enum vcpu_state secondary_state);
35
Andrew Scull33fecd32019-01-08 14:48:27 +000036struct vcpu *api_preempt(struct vcpu *current);
Andrew Scull33fecd32019-01-08 14:48:27 +000037struct vcpu *api_wait_for_interrupt(struct vcpu *current);
Andrew Walbran33645652019-04-15 12:29:31 +010038struct vcpu *api_vcpu_off(struct vcpu *current);
Andrew Scull9726c252019-01-23 13:44:19 +000039struct vcpu *api_abort(struct vcpu *current);
Andrew Walbran33645652019-04-15 12:29:31 +010040struct vcpu *api_wake_up(struct vcpu *current, struct vcpu *target_vcpu);
Andrew Walbran318f5732018-11-20 16:23:42 +000041
Manish Pandey35e452f2021-02-18 21:36:34 +000042int64_t api_interrupt_enable(uint32_t intid, bool enable,
43 enum interrupt_type type, struct vcpu *current);
Madhukar Pappireddyc64d0642024-08-07 16:55:46 -050044uint32_t api_interrupt_get(struct vcpu_locked current_locked);
Daniel Boulby84d49b62024-11-04 18:25:59 +000045int64_t api_hf_interrupt_send_ipi(uint32_t target_vcpu_id,
46 struct vcpu *current);
Jose Marinhoa1dfeda2019-02-27 16:46:03 +000047
J-Alves19e20cf2023-08-02 12:48:55 +010048struct ffa_value api_ffa_msg_send(ffa_id_t sender_vm_id,
49 ffa_id_t receiver_vm_id, uint32_t size,
Federico Recanati86f6cde2022-04-28 19:44:49 +020050 struct vcpu *current, struct vcpu **next);
Karl Meakin8e3d7bc2024-12-12 15:52:19 +000051struct ffa_value api_ffa_msg_send2(ffa_id_t sender_id, uint32_t flags,
Federico Recanati25053ee2022-03-14 15:01:53 +010052 struct vcpu *current);
J-Alves19e20cf2023-08-02 12:48:55 +010053struct ffa_value api_ffa_rx_release(ffa_id_t receiver_id, struct vcpu *current);
54struct ffa_value api_ffa_rx_acquire(ffa_id_t receiver_id, struct vcpu *current);
Manish Pandeyd34f8892020-06-19 17:41:07 +010055struct ffa_value api_vm_configure_pages(
56 struct mm_stage1_locked mm_stage1_locked, struct vm_locked vm_locked,
57 ipaddr_t send, ipaddr_t recv, uint32_t page_count,
58 struct mpool *local_page_pool);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010059struct ffa_value api_ffa_rxtx_map(ipaddr_t send, ipaddr_t recv,
Federico Recanati9f1b6532022-04-14 13:15:28 +020060 uint32_t page_count, struct vcpu *current);
J-Alves19e20cf2023-08-02 12:48:55 +010061struct ffa_value api_ffa_rxtx_unmap(ffa_id_t allocator_id,
Daniel Boulby9e420ca2021-07-07 15:03:49 +010062 struct vcpu *current);
Madhukar Pappireddy184501c2023-05-23 17:24:06 -050063struct ffa_value api_yield(struct vcpu *current, struct vcpu **next,
64 struct ffa_value *args);
Daniel Boulbybaeaf2e2021-12-09 11:42:36 +000065struct ffa_value api_ffa_version(struct vcpu *current,
66 uint32_t requested_version);
Fuad Tabbae4efcc32020-07-16 15:37:27 +010067struct ffa_value api_ffa_partition_info_get(struct vcpu *current,
Daniel Boulbyb46cad12021-12-13 17:47:21 +000068 const struct ffa_uuid *uuid,
Karl Meakin2ad6b662024-07-29 20:45:40 +010069 uint32_t flags);
Raghu Krishnamurthy2d2b0f42023-04-23 09:54:45 -070070bool api_ffa_fill_partition_info_from_regs(
71 struct ffa_value ret, uint16_t start_index,
72 struct ffa_partition_info *partitions, uint16_t partitions_len,
73 ffa_vm_count_t *ret_count);
Raghu Krishnamurthy7592bcb2022-12-25 13:09:00 -080074struct ffa_value api_ffa_partition_info_get_regs(struct vcpu *current,
75 const struct ffa_uuid *uuid,
Karl Meakin2ad6b662024-07-29 20:45:40 +010076 uint16_t start_index,
77 uint16_t tag);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010078struct ffa_value api_ffa_id_get(const struct vcpu *current);
Daniel Boulbyb2fb80e2021-02-03 15:09:23 +000079struct ffa_value api_ffa_spm_id_get(void);
J-Alves6f72ca82021-11-01 12:34:58 +000080struct ffa_value api_ffa_feature_success(uint32_t arg2);
Karl Meakin49ec1e42024-05-10 13:08:24 +010081struct ffa_value api_ffa_features(uint32_t function_or_feature_id,
Karl Meakinf1ed5f12024-02-22 15:57:36 +000082 uint32_t input_property,
83 struct vcpu *current);
Madhukar Pappireddy5522c672021-12-17 16:35:51 -060084struct ffa_value api_ffa_msg_wait(struct vcpu *current, struct vcpu **next,
85 struct ffa_value *args);
J-Alves19e20cf2023-08-02 12:48:55 +010086struct ffa_value api_ffa_run(ffa_id_t vm_id, ffa_vcpu_index_t vcpu_idx,
Madhukar Pappireddyb11e0d12021-08-02 19:44:35 -050087 struct vcpu *current, struct vcpu **next);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010088struct ffa_value api_ffa_mem_send(uint32_t share_func, uint32_t length,
89 uint32_t fragment_length, ipaddr_t address,
Andrew Walbran1a86aa92020-05-15 17:22:28 +010090 uint32_t page_count, struct vcpu *current);
Andrew Walbranb5ab43c2020-04-30 11:32:54 +010091struct ffa_value api_ffa_mem_retrieve_req(uint32_t length,
92 uint32_t fragment_length,
93 ipaddr_t address, uint32_t page_count,
94 struct vcpu *current);
95struct ffa_value api_ffa_mem_relinquish(struct vcpu *current);
96struct ffa_value api_ffa_mem_reclaim(ffa_memory_handle_t handle,
97 ffa_memory_region_flags_t flags,
98 struct vcpu *current);
Andrew Walbranca808b12020-05-15 17:22:28 +010099struct ffa_value api_ffa_mem_frag_rx(ffa_memory_handle_t handle,
100 uint32_t fragment_offset,
J-Alves19e20cf2023-08-02 12:48:55 +0100101 ffa_id_t sender_vm_id,
Andrew Walbranca808b12020-05-15 17:22:28 +0100102 struct vcpu *current);
103struct ffa_value api_ffa_mem_frag_tx(ffa_memory_handle_t handle,
104 uint32_t fragment_length,
J-Alves19e20cf2023-08-02 12:48:55 +0100105 ffa_id_t sender_vm_id,
Andrew Walbranca808b12020-05-15 17:22:28 +0100106 struct vcpu *current);
Karl Meakin13f09812024-10-28 16:33:23 +0000107struct ffa_value api_ffa_msg_send_direct_req(struct ffa_value args,
Olivier Deprezee9d6a92019-11-26 09:14:11 +0000108 struct vcpu *current,
109 struct vcpu **next);
Karl Meakin13f09812024-10-28 16:33:23 +0000110struct ffa_value api_ffa_msg_send_direct_resp(struct ffa_value args,
Olivier Deprezee9d6a92019-11-26 09:14:11 +0000111 struct vcpu *current,
112 struct vcpu **next);
Max Shvetsov40108e72020-08-27 12:39:50 +0100113struct ffa_value api_ffa_secondary_ep_register(ipaddr_t entry_point,
114 struct vcpu *current);
Madhukar Pappireddybd10e572023-03-06 16:39:49 -0600115struct vcpu *api_switch_to_other_world(struct vcpu_locked current_locked,
Manish Pandeya5f39fb2020-09-11 09:47:11 +0100116 struct ffa_value other_world_ret,
117 enum vcpu_state vcpu_state);
J-Alves19e20cf2023-08-02 12:48:55 +0100118struct ffa_value api_ffa_notification_bitmap_create(ffa_id_t vm_id,
J-Alvesa0f317d2021-06-09 13:31:59 +0100119 ffa_vcpu_count_t vcpu_count,
120 struct vcpu *current);
J-Alves19e20cf2023-08-02 12:48:55 +0100121struct ffa_value api_ffa_notification_bitmap_destroy(ffa_id_t vm_id,
J-Alvesa0f317d2021-06-09 13:31:59 +0100122 struct vcpu *current);
J-Alvesc003a7a2021-03-18 13:06:53 +0000123
124struct ffa_value api_ffa_notification_update_bindings(
Karl Meakinf9c73ce2024-07-30 17:37:13 +0100125 ffa_id_t sender_vm_id, ffa_id_t receiver_vm_id,
126 ffa_notification_flags_t flags,
J-Alvesc003a7a2021-03-18 13:06:53 +0000127 ffa_notifications_bitmap_t notifications, bool is_bind,
128 struct vcpu *current);
J-Alvesaa79c012021-07-09 14:29:45 +0100129
130struct ffa_value api_ffa_notification_set(
Karl Meakinf9c73ce2024-07-30 17:37:13 +0100131 ffa_id_t sender_vm_id, ffa_id_t receiver_vm_id,
132 ffa_notification_flags_t flags,
J-Alvesaa79c012021-07-09 14:29:45 +0100133 ffa_notifications_bitmap_t notifications, struct vcpu *current);
134
J-Alves19e20cf2023-08-02 12:48:55 +0100135struct ffa_value api_ffa_notification_get(ffa_id_t receiver_vm_id,
Karl Meakinf9c73ce2024-07-30 17:37:13 +0100136 uint16_t vcpu_id,
137 ffa_notification_flags_t flags,
J-Alvesaa79c012021-07-09 14:29:45 +0100138 struct vcpu *current);
J-Alvesc8e8a222021-06-08 17:33:52 +0100139
140struct ffa_value api_ffa_notification_info_get(struct vcpu *current);
Raghu Krishnamurthyea6d25f2021-09-14 15:27:06 -0700141
142struct ffa_value api_ffa_mem_perm_get(vaddr_t base_addr, struct vcpu *current);
143struct ffa_value api_ffa_mem_perm_set(vaddr_t base_addr, uint32_t page_count,
Karl Meakin80220052025-02-20 14:43:34 +0000144 enum ffa_mem_perm mem_perm,
145 struct vcpu *current);
Maksims Svecovs71b76702022-05-20 15:32:58 +0100146
Karl Meakin6f1f1212024-07-16 10:18:16 +0100147void api_flush_log_buffer(struct vcpu_locked *vcpu_locked);
Karl Meakin2ad6b662024-07-29 20:45:40 +0100148struct ffa_value api_ffa_console_log(struct ffa_value args,
Maksims Svecovs71b76702022-05-20 15:32:58 +0100149 struct vcpu *current);
Madhukar Pappireddy2f76e492022-09-06 15:21:59 -0500150
Madhukar Pappireddybd10e572023-03-06 16:39:49 -0600151void api_ffa_resume_direct_resp_target(struct vcpu_locked current_locked,
152 struct vcpu **next,
J-Alves19e20cf2023-08-02 12:48:55 +0100153 ffa_id_t receiver_vm_id,
Madhukar Pappireddy2f76e492022-09-06 15:21:59 -0500154 struct ffa_value to_ret,
155 bool is_nwd_call_chain);
Kathleen Capella036cc592023-11-30 18:26:15 -0500156
157bool api_extended_args_are_zero(struct ffa_value *args);