mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-12-13 14:53:06 +00:00
34 lines
815 B
C
34 lines
815 B
C
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
||
|
/*
|
||
|
* Simple API for configuring TrustZone memory regions
|
||
|
*
|
||
|
* The premise is that the desired TZC layout is known beforehand, and it can
|
||
|
* be configured in one step. tzc_configure() provides this functionality.
|
||
|
*/
|
||
|
#ifndef MACH_TZC_H
|
||
|
#define MACH_TZC_H
|
||
|
|
||
|
#include <linux/types.h>
|
||
|
|
||
|
enum tzc_sec_mode {
|
||
|
TZC_ATTR_SEC_NONE = 0,
|
||
|
TZC_ATTR_SEC_R = 1,
|
||
|
TZC_ATTR_SEC_W = 2,
|
||
|
TZC_ATTR_SEC_RW = 3
|
||
|
};
|
||
|
|
||
|
struct tzc_region {
|
||
|
uintptr_t base;
|
||
|
uintptr_t top;
|
||
|
enum tzc_sec_mode sec_mode;
|
||
|
uint16_t nsec_id;
|
||
|
uint16_t filters_mask;
|
||
|
};
|
||
|
|
||
|
int tzc_configure(uintptr_t tzc, const struct tzc_region *cfg);
|
||
|
int tzc_disable_filters(uintptr_t tzc, uint16_t filters_mask);
|
||
|
int tzc_enable_filters(uintptr_t tzc, uint16_t filters_mask);
|
||
|
void tzc_dump_config(uintptr_t tzc);
|
||
|
|
||
|
#endif /* MACH_TZC_H */
|