blob: 57ce1701f71154205e025bb6d711298281e45481 [file] [log] [blame]
Daniel Boulbyb2fb80e2021-02-03 15:09:23 +00001/*
2 * Copyright 2021 The Hafnium Authors.
3 *
4 * 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.
7 */
8
9#pragma once
10
11#include "hf/ffa.h"
Olivier Deprez55a189e2021-06-09 15:45:27 +020012#include "hf/vcpu.h"
Daniel Boulbyb2fb80e2021-02-03 15:09:23 +000013
14/** Returns the SPMC ID. */
15struct ffa_value plat_ffa_spmc_id_get(void);
Olivier Deprez55a189e2021-06-09 15:45:27 +020016
17void plat_ffa_log_init(void);
18void plat_ffa_init(bool tee_enabled);
19bool plat_ffa_is_direct_request_valid(struct vcpu *current,
20 ffa_vm_id_t sender_vm_id,
21 ffa_vm_id_t receiver_vm_id);
22bool plat_ffa_is_direct_response_valid(struct vcpu *current,
23 ffa_vm_id_t sender_vm_id,
24 ffa_vm_id_t receiver_vm_id);
25bool plat_ffa_direct_request_forward(ffa_vm_id_t receiver_vm_id,
26 struct ffa_value args,
27 struct ffa_value *ret);
J-Alvesa0f317d2021-06-09 13:31:59 +010028bool plat_ffa_is_notifications_create_valid(struct vcpu *current,
29 ffa_vm_id_t vm_id);
Olivier Deprez55a189e2021-06-09 15:45:27 +020030/**
Maksims Svecovs9ddf86a2021-05-06 17:17:21 +010031 * Checks whether managed exit is supported by given SP.
32 */
33bool plat_ffa_vm_managed_exit_supported(struct vm *vm);
34
35/**
Olivier Deprez55a189e2021-06-09 15:45:27 +020036 * Encodes memory handle according to section 5.10.2 of the FF-A v1.0 spec.
37 */
38ffa_memory_handle_t plat_ffa_memory_handle_make(uint64_t index);
39
40/**
41 * Checks whether given handle was allocated by current world, according to
42 * handle encoding rules.
43 */
44bool plat_ffa_memory_handle_allocated_by_current_world(
45 ffa_memory_handle_t handle);
Maksims Svecovsb596eab2021-04-27 00:52:27 +010046
47/**
48 * Return the FF-A partition info VM/SP properties given the VM id.
49 */
50ffa_partition_properties_t plat_ffa_partition_properties(
51 ffa_vm_id_t current_id, const struct vm *target);
J-Alves4ef6e842021-03-18 12:47:01 +000052
53/**
54 * Initializes the NWd VM structures for Notifications support.
55 */
56void plat_ffa_vm_init(void);
J-Alvesa0f317d2021-06-09 13:31:59 +010057
58/**
59 * Get NWd VM's structure.
60 */
61struct vm_locked plat_ffa_vm_find_locked(ffa_vm_id_t vm_id);
62
63/**
64 * Creates a bitmap for the VM of the given ID.
65 */
66struct ffa_value plat_ffa_notifications_bitmap_create(
67 ffa_vm_id_t vm_id, ffa_vcpu_count_t vcpu_count);
68
69/**
70 * Destroys the notifications bitmap for the given VM ID.
71 */
72struct ffa_value plat_ffa_notifications_bitmap_destroy(ffa_vm_id_t vm_id);