2020-11-13 06:01:31 +08:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
|
|
|
/*
|
|
|
|
* Copyright(c) 2016-20 Intel Corporation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MAIN_H
|
|
|
|
#define MAIN_H
|
|
|
|
|
2021-11-16 02:35:17 +08:00
|
|
|
#define ENCL_HEAP_SIZE_DEFAULT 4096
|
|
|
|
|
2020-11-13 06:01:31 +08:00
|
|
|
struct encl_segment {
|
2021-11-16 02:35:15 +08:00
|
|
|
void *src;
|
2020-11-13 06:01:31 +08:00
|
|
|
off_t offset;
|
|
|
|
size_t size;
|
|
|
|
unsigned int prot;
|
|
|
|
unsigned int flags;
|
2021-11-16 02:35:16 +08:00
|
|
|
bool measure;
|
2020-11-13 06:01:31 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct encl {
|
|
|
|
int fd;
|
|
|
|
void *bin;
|
|
|
|
off_t bin_size;
|
|
|
|
void *src;
|
|
|
|
size_t src_size;
|
|
|
|
size_t encl_size;
|
|
|
|
off_t encl_base;
|
|
|
|
unsigned int nr_segments;
|
|
|
|
struct encl_segment *segment_tbl;
|
|
|
|
struct sgx_secs secs;
|
|
|
|
struct sgx_sigstruct sigstruct;
|
|
|
|
};
|
|
|
|
|
2020-11-19 01:06:40 +08:00
|
|
|
extern unsigned char sign_key[];
|
|
|
|
extern unsigned char sign_key_end[];
|
|
|
|
|
2020-11-13 06:01:31 +08:00
|
|
|
void encl_delete(struct encl *ctx);
|
2021-11-16 02:35:17 +08:00
|
|
|
bool encl_load(const char *path, struct encl *encl, unsigned long heap_size);
|
2020-11-13 06:01:31 +08:00
|
|
|
bool encl_measure(struct encl *encl);
|
|
|
|
bool encl_build(struct encl *encl);
|
2022-05-11 02:09:03 +08:00
|
|
|
uint64_t encl_get_entry(struct encl *encl, const char *symbol);
|
2020-11-13 06:01:31 +08:00
|
|
|
|
2021-06-10 16:30:17 +08:00
|
|
|
int sgx_enter_enclave(void *rdi, void *rsi, long rdx, u32 function, void *r8, void *r9,
|
|
|
|
struct sgx_enclave_run *run);
|
2020-11-13 06:01:31 +08:00
|
|
|
|
|
|
|
#endif /* MAIN_H */
|