blob: e798bca885c21992c44fffbcb3e09c5844166b09 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
/*
Vita Development Suite Libraries
*/
#ifndef _VDSUITE_USER_KERNEL_MODULEMGR_H
#define _VDSUITE_USER_KERNEL_MODULEMGR_H
#include_next <kernel/modulemgr.h>
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
typedef enum SceKernelModuleState {
SCE_KERNEL_MODULE_STATE_READY = 0x00000002,
SCE_KERNEL_MODULE_STATE_STARTED = 0x00000006,
SCE_KERNEL_MODULE_STATE_ENDED = 0x00000009
} SceKernelModuleState;
typedef struct SceKernelSegmentInfo {
SceSize size; //!< this structure size (0x18)
SceUInt perms; //!< probably rwx in low bits
void *vaddr; //!< address in memory
SceSize memsz; //!< size in memory
SceSize filesz; //!< original size of memsz
SceUInt res; //!< unused
} SceKernelSegmentInfo;
typedef struct SceKernelModuleInfo {
SceSize size; //!< 0x1B8 for Vita 1.x
SceUID modid;
uint16_t modattr;
uint8_t modver[2];
char module_name[28];
SceUInt unk28;
void *start_entry;
void *stop_entry;
void *exit_entry;
void *exidx_top;
void *exidx_btm;
void *extab_top;
void *extab_btm;
void *tlsInit;
SceSize tlsInitSize;
SceSize tlsAreaSize;
char path[256];
SceKernelSegmentInfo segments[4];
SceUInt state; //!< see:SceKernelModuleState
} SceKernelModuleInfo;
int sceKernelGetModuleList(int flags, SceUID *modids, SceSize *num);
int sceKernelGetModuleInfo(SceUID modid, SceKernelModuleInfo *info);
typedef struct SceKernelFwInfo {
SceSize size;
char versionString[0x1C];
SceUInt version;
SceUInt unk_24;
} SceKernelFwInfo;
/**
* Gets system firmware information.
*
* @param[out] data - firmware information.
*
* @note - If you spoofed the firmware version it will return the spoofed firmware.
*/
int sceKernelGetSystemSwVersion(SceKernelFwInfo *data);
#ifdef __cplusplus
}
#endif
#endif /* _VDSUITE_USER_KERNEL_MODULEMGR_H */
|