test

Dependencies:   mbed Watchdog

Dependents:   STM32-MC_node

Committer:
ommpy
Date:
Mon Jul 06 17:18:59 2020 +0530
Revision:
0:d383e2dee0f7
first commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ommpy 0:d383e2dee0f7 1
ommpy 0:d383e2dee0f7 2 /** \addtogroup hal */
ommpy 0:d383e2dee0f7 3 /** @{*/
ommpy 0:d383e2dee0f7 4 /* Copyright (c) 2017-2018 ARM Limited
ommpy 0:d383e2dee0f7 5 *
ommpy 0:d383e2dee0f7 6 * SPDX-License-Identifier: Apache-2.0
ommpy 0:d383e2dee0f7 7 *
ommpy 0:d383e2dee0f7 8 * Licensed under the Apache License, Version 2.0 (the "License");
ommpy 0:d383e2dee0f7 9 * you may not use this file except in compliance with the License.
ommpy 0:d383e2dee0f7 10 * You may obtain a copy of the License at
ommpy 0:d383e2dee0f7 11 *
ommpy 0:d383e2dee0f7 12 * http://www.apache.org/licenses/LICENSE-2.0
ommpy 0:d383e2dee0f7 13 *
ommpy 0:d383e2dee0f7 14 * Unless required by applicable law or agreed to in writing, software
ommpy 0:d383e2dee0f7 15 * distributed under the License is distributed on an "AS IS" BASIS,
ommpy 0:d383e2dee0f7 16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
ommpy 0:d383e2dee0f7 17 * See the License for the specific language governing permissions and
ommpy 0:d383e2dee0f7 18 * limitations under the License.
ommpy 0:d383e2dee0f7 19 */
ommpy 0:d383e2dee0f7 20
ommpy 0:d383e2dee0f7 21 #ifndef __SPM_API_H__
ommpy 0:d383e2dee0f7 22 #define __SPM_API_H__
ommpy 0:d383e2dee0f7 23
ommpy 0:d383e2dee0f7 24 #include <stdint.h>
ommpy 0:d383e2dee0f7 25 #include <stddef.h>
ommpy 0:d383e2dee0f7 26
ommpy 0:d383e2dee0f7 27 #ifdef __cplusplus
ommpy 0:d383e2dee0f7 28 extern "C" {
ommpy 0:d383e2dee0f7 29 #endif
ommpy 0:d383e2dee0f7 30
ommpy 0:d383e2dee0f7 31
ommpy 0:d383e2dee0f7 32 /** @defgroup SPM-HAL SPM HAL API
ommpy 0:d383e2dee0f7 33 * The HAL functions for PSA SPM
ommpy 0:d383e2dee0f7 34 * @{
ommpy 0:d383e2dee0f7 35 */
ommpy 0:d383e2dee0f7 36
ommpy 0:d383e2dee0f7 37
ommpy 0:d383e2dee0f7 38 /* ------------------------------------ HAL-SPE API ------------------------- */
ommpy 0:d383e2dee0f7 39
ommpy 0:d383e2dee0f7 40
ommpy 0:d383e2dee0f7 41 #if defined(COMPONENT_SPE)
ommpy 0:d383e2dee0f7 42 /**
ommpy 0:d383e2dee0f7 43 * Start running the NSPE.
ommpy 0:d383e2dee0f7 44 *
ommpy 0:d383e2dee0f7 45 * Secure Processing Environment (SPE) expected to boot first. Once all
ommpy 0:d383e2dee0f7 46 * the initializations are done, Nonsecure Processing Environment (NSPE)
ommpy 0:d383e2dee0f7 47 * should be booted.
ommpy 0:d383e2dee0f7 48 *
ommpy 0:d383e2dee0f7 49 * @note The function must be implemented by target specific code.
ommpy 0:d383e2dee0f7 50 */
ommpy 0:d383e2dee0f7 51 void spm_hal_start_nspe(void);
ommpy 0:d383e2dee0f7 52
ommpy 0:d383e2dee0f7 53
ommpy 0:d383e2dee0f7 54 /**
ommpy 0:d383e2dee0f7 55 * Configure memory protection mechanism.
ommpy 0:d383e2dee0f7 56 *
ommpy 0:d383e2dee0f7 57 * Apply memory protection schemes to ensure secure memory can only be accessed
ommpy 0:d383e2dee0f7 58 * from secure-state.
ommpy 0:d383e2dee0f7 59 *
ommpy 0:d383e2dee0f7 60 * @note The function must be implemented by target specific code.
ommpy 0:d383e2dee0f7 61 *
ommpy 0:d383e2dee0f7 62 */
ommpy 0:d383e2dee0f7 63 void spm_hal_memory_protection_init(void);
ommpy 0:d383e2dee0f7 64
ommpy 0:d383e2dee0f7 65 #endif // defined(COMPONENT_SPE)
ommpy 0:d383e2dee0f7 66
ommpy 0:d383e2dee0f7 67 /* ---------------------------------- HAL-Mailbox API ----------------------- */
ommpy 0:d383e2dee0f7 68
ommpy 0:d383e2dee0f7 69 #if defined(COMPONENT_SPM_MAILBOX)
ommpy 0:d383e2dee0f7 70 /**
ommpy 0:d383e2dee0f7 71 * @brief Wakeup mailbox dispatcher thread
ommpy 0:d383e2dee0f7 72 *
ommpy 0:d383e2dee0f7 73 * Arm implements this function, which is expected to be called by target-
ommpy 0:d383e2dee0f7 74 * specific Inter-Processor-Communication logic on mailbox interrupt handler.
ommpy 0:d383e2dee0f7 75 *
ommpy 0:d383e2dee0f7 76 */
ommpy 0:d383e2dee0f7 77 void spm_mailbox_irq_callback(void);
ommpy 0:d383e2dee0f7 78
ommpy 0:d383e2dee0f7 79 /**
ommpy 0:d383e2dee0f7 80 * @brief Notify the peer processor about a general event occurrence.
ommpy 0:d383e2dee0f7 81 *
ommpy 0:d383e2dee0f7 82 * Wake up the peer processor waiting on the mailbox driver event.
ommpy 0:d383e2dee0f7 83 *
ommpy 0:d383e2dee0f7 84 * @note Implement the functions below with target-specific code.
ommpy 0:d383e2dee0f7 85 */
ommpy 0:d383e2dee0f7 86 void spm_hal_mailbox_notify(void);
ommpy 0:d383e2dee0f7 87
ommpy 0:d383e2dee0f7 88 #endif // defined(COMPONENT_SPM_MAILBOX)
ommpy 0:d383e2dee0f7 89
ommpy 0:d383e2dee0f7 90 /** @}*/
ommpy 0:d383e2dee0f7 91
ommpy 0:d383e2dee0f7 92 #ifdef __cplusplus
ommpy 0:d383e2dee0f7 93 }
ommpy 0:d383e2dee0f7 94 #endif
ommpy 0:d383e2dee0f7 95
ommpy 0:d383e2dee0f7 96 #endif // __SPM_API_H__
ommpy 0:d383e2dee0f7 97
ommpy 0:d383e2dee0f7 98 /** @}*/