116 lines
2.3 KiB
C
Executable file
116 lines
2.3 KiB
C
Executable file
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __RKP_H__
|
|
#define __RKP_H__
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
#include <linux/types.h>
|
|
|
|
#ifdef CONFIG_RKP_TEST
|
|
#define RKP_INIT_MAGIC 0x5afe0002
|
|
#else
|
|
#define RKP_INIT_MAGIC 0x5afe0001
|
|
#endif
|
|
|
|
#define __rkp_ro __section(".rkp_ro")
|
|
|
|
enum __RKP_CMD_ID {
|
|
RKP_START = 0x00,
|
|
RKP_DEFERRED_START = 0x01,
|
|
/* RKP robuffer cmds*/
|
|
RKP_GET_RO_INFO = 0x2,
|
|
RKP_CHG_RO = 0x03,
|
|
RKP_CHG_RW = 0x04,
|
|
RKP_PGD_RO = 0x05,
|
|
RKP_PGD_RW = 0x06,
|
|
RKP_ROBUFFER_ALLOC = 0x07,
|
|
RKP_ROBUFFER_FREE = 0x08,
|
|
/* module, binary load */
|
|
RKP_DYNAMIC_LOAD = 0x09,
|
|
RKP_MODULE_LOAD = 0x0A,
|
|
RKP_BPF_LOAD = 0x0B,
|
|
/* Log */
|
|
RKP_LOG = 0x0C,
|
|
#ifdef CONFIG_RKP_TEST
|
|
RKP_TEST_INIT = 0x0D,
|
|
RKP_TEST_GET_PAR = 0x0E,
|
|
RKP_TEST_EXIT = 0x0F,
|
|
RKP_TEST_TEXT_VALID = 0x12,
|
|
#endif
|
|
RKP_KPROBE_PAGE = 0x11,
|
|
};
|
|
|
|
#define RKP_DYN_COMMAND_BREAKDOWN 0x00
|
|
#define RKP_DYN_COMMAND_INS 0x01
|
|
#define RKP_DYN_COMMAND_RM 0x10
|
|
#define RKP_DYN_COMMAND_PREPARE 0x20
|
|
|
|
#define RKP_DYN_FIMC 0x02
|
|
#define RKP_DYN_FIMC_COMBINED 0x03
|
|
|
|
#define RKP_MODULE_PXN_CLEAR 0x1
|
|
#define RKP_MODULE_PXN_SET 0x2
|
|
|
|
#define RKP_MODULE_NAME_LEN 15
|
|
|
|
struct rkp_init { //copy from uh (app/rkp/rkp.h)
|
|
u32 magic;
|
|
u64 vmalloc_start;
|
|
u64 vmalloc_end;
|
|
u64 init_mm_pgd;
|
|
u64 id_map_pgd;
|
|
u64 zero_pg_addr;
|
|
u64 rkp_pgt_bitmap;
|
|
u64 rkp_dbl_bitmap;
|
|
u32 rkp_bitmap_size;
|
|
u32 no_fimc_verify;
|
|
u64 fimc_phys_addr;
|
|
u64 _text;
|
|
u64 _etext;
|
|
u64 extra_memory_addr;
|
|
u32 extra_memory_size;
|
|
u64 physmap_addr; //not used. what is this for?
|
|
u64 _srodata;
|
|
u64 _erodata;
|
|
u32 large_memory;
|
|
u64 tramp_pgd;
|
|
u64 tramp_valias;
|
|
/* for s2pxn feature */
|
|
u64 _sinit_text;
|
|
u64 _einit_text;
|
|
};
|
|
|
|
struct rkp_dynamic_load {
|
|
u32 type;
|
|
u64 binary_base;
|
|
u64 binary_size;
|
|
u64 code_base1;
|
|
u64 code_size1;
|
|
u64 code_base2;
|
|
u64 code_size2;
|
|
};
|
|
|
|
struct module_info {
|
|
u64 base_va;
|
|
u64 vm_size;
|
|
u64 core_base_va;
|
|
u64 core_text_size;
|
|
u64 core_ro_size;
|
|
u64 init_base_va;
|
|
u64 init_text_size;
|
|
u8 module_name[RKP_MODULE_NAME_LEN];
|
|
};
|
|
|
|
extern bool rkp_started;
|
|
|
|
extern void __init rkp_init(void);
|
|
extern void rkp_deferred_init(void);
|
|
extern void rkp_robuffer_init(void);
|
|
|
|
extern inline phys_addr_t rkp_ro_alloc_phys(int shift);
|
|
extern inline void *rkp_ro_alloc(void);
|
|
extern inline void rkp_ro_free(void *free_addr);
|
|
extern inline bool is_rkp_ro_buffer(u64 addr);
|
|
|
|
#endif //__ASSEMBLY__
|
|
#endif //__RKP_H__
|