2018-02-19 20:18:53 -08:00
|
|
|
#ifndef EXOSPHERE_USERPAGE_H
|
|
|
|
#define EXOSPHERE_USERPAGE_H
|
|
|
|
|
2018-02-25 15:05:52 +01:00
|
|
|
#include "utils.h"
|
|
|
|
#include "memory_map.h"
|
2018-02-19 20:18:53 -08:00
|
|
|
|
2018-02-26 22:09:35 +01:00
|
|
|
static inline uintptr_t get_user_page_secure_monitor_addr(void) {
|
|
|
|
return TZRAM_GET_SEGMENT_ADDRESS(TZRAM_SEGMENT_ID_USERPAGE);
|
|
|
|
}
|
|
|
|
|
|
|
|
#define USER_PAGE_SECURE_MONITOR_ADDR (get_user_page_secure_monitor_addr())
|
2018-02-19 20:18:53 -08:00
|
|
|
|
|
|
|
typedef struct {
|
2018-02-25 15:05:52 +01:00
|
|
|
uintptr_t user_address;
|
|
|
|
uintptr_t secure_monitor_address;
|
2018-02-19 20:18:53 -08:00
|
|
|
} upage_ref_t;
|
|
|
|
|
2018-02-22 22:58:39 -05:00
|
|
|
bool upage_init(upage_ref_t *user_page, void *user_address);
|
2018-02-19 20:18:53 -08:00
|
|
|
|
2018-02-22 22:58:39 -05:00
|
|
|
bool user_copy_to_secure(upage_ref_t *user_page, void *secure_dst, void *user_src, size_t size);
|
|
|
|
bool secure_copy_to_user(upage_ref_t *user_page, void *user_dst, void *secure_src, size_t size);
|
2018-02-19 20:18:53 -08:00
|
|
|
|
2018-02-25 15:05:52 +01:00
|
|
|
#endif
|