Difference between revisions of "NSKBL Subroutines"

From Vita Development Wiki
Jump to navigation Jump to search
Line 306: Line 306:
  
 
<source lang="C">void sceKernelCpuDcacheAndL2WritebackRange(void *data, SceSize size);</source>
 
<source lang="C">void sceKernelCpuDcacheAndL2WritebackRange(void *data, SceSize size);</source>
 +
 +
=== sceKernelCpuSuspendIntr ===
 +
 +
{| class="wikitable"
 +
|-
 +
! Version !! offset !! mode
 +
|-
 +
| 3.60 || 0x51014838 || thumb
 +
|}
 +
 +
<source lang="C">int sceKernelCpuSuspendIntr(int *addr);</source>
 +
 +
=== sceKernelCpuResumeIntr ===
 +
 +
{| class="wikitable"
 +
|-
 +
! Version !! offset !! mode
 +
|-
 +
| 3.60 || 0x51014864 || thumb
 +
|}
 +
 +
<source lang="C">int sceKernelCpuResumeIntr(int *addr, int prev_state);</source>
  
 
=== vaddr_to_paddr_with_mode ===
 
=== vaddr_to_paddr_with_mode ===

Revision as of 15:31, 28 July 2020

Common data

pSceUIDModuleClass

Version offset size description
3.60 0x5113F39C 4 pointer of SceClass.

There is no mistake that there are two

pSceUIDModuleClass

Version offset size description
3.60 0x5113F3A4 4 pointer of SceClass.

pSceUIDLibStubClass

Version offset size description
3.60 0x5113F3A8 4 pointer of SceClass.

pSceUIDLibraryClass

Version offset size description
3.60 0x5113F3AC 4 pointer of SceClass.

Common functions

read_sector

Version offset mode
3.60 0x510010FC thumb

call read_sector_direct.

int read_sector(void *ctx, unsigned int sector_pos, unsigned int sector_num, void *data);

read_sector_direct

Version offset mode
3.60 0x510010C4 thumb
int read_sector_direct(void *ctx, unsigned int sector_pos, unsigned int sector_num, void *data);

sceKernelCreateClass

Version offset mode
3.60 0x510059A0 thumb
int sceKernelCreateClass(SceClass *cls, const char *name, void *uidclass, SceSize itemsize, SceClassCallback create, SceClassCallback destroy);

sceKernelGetUidClass

Version offset mode
3.60 0x51005A04 thumb
SceClass *sceKernelGetUidClass(void);

sceGUIDReferObjectWithClass

Version offset mode
3.60 0x510069E8 thumb
int sceGUIDReferObjectWithClass(SceUID uid, SceClass *pClass, SceKernelObject **ppEntry);

sceKernelUidRelease

Version offset mode
3.60 0x51006A50 thumb
int sceKernelUidRelease(SceUID uid);

sceKernelSysrootGetKblParam

Version offset mode
3.60 0x51012244 thumb
void *sceKernelSysrootGetKblParam(void);

sceKernelSysrootSetModulePrivate

Version offset mode
3.60 0x510124D0 thumb
void sceKernelSysrootSetModulePrivate(int idx, void *data);

sceKernelSysrootUseExternalStorage

Version offset mode
3.60 0x510128D4 thumb
int sceKernelSysrootUseExternalStorage(void);

sceKernelSysrootIsExternalBootMode

Version offset mode
3.60 0x510128E8 thumb
int sceKernelSysrootIsExternalBootMode(void);

__stack_chk_fail

Version offset mode
3.60 0x51014508 thumb
void __stack_chk_fail(void);

strlen

Version offset mode
3.60 0x51013B7C thumb
SceSize strlen(const char *s);

strnlen

Version offset mode
3.60 0x51013B80 thumb
SceSize strnlen(const char *s, SceSize maxlen);

SceSysclibForDriver_E38E7605

Version offset mode
3.60 0x51013BD0 thumb

same as non-secure SceSysmem -> SceSysclibForDriver_E38E7605.

typedef struct SceKernelPrintFmt {
	int dstlen;
	int res; // output length
	char *dst;
} SceKernelPrintFmt;

int SceSysclibForDriver_E38E7605(const void *some_cb, SceKernelPrintFmt *ctx, const char *fmt, va_list list);

snprintf

Version offset mode
3.60 0x51014458 thumb
int snprintf(char *dst, int dstmax, const char *fmt, ...);

strncpy

Version offset mode
3.60 0x510144A0 thumb
char *strncpy(char *dst, const char *src, SceSize len);

sceKernelCpuIcacheInvalidateAll

Version offset mode
3.60 0x51014520 thumb
void sceKernelCpuIcacheInvalidateAll(void);

sceKernelCpuIcacheInvalidateRange

Version offset mode
3.60 0x51014530 thumb
void sceKernelCpuIcacheInvalidateRange(void *data, SceSize size);

sceKernelCpuDcacheInvalidateMVACRange

Version offset mode
3.60 0x5101454C thumb
void sceKernelCpuDcacheInvalidateMVACRange(void *data, SceSize size);

sceKernelCpuDcacheCleanMVACRange

Version offset mode
3.60 0x5101456C thumb
void sceKernelCpuDcacheCleanMVACRange(void *data, SceSize size);

sceKernelCpuDcacheWritebackInvalidateRange

Version offset mode
3.60 0x5101458C thumb
void sceKernelCpuDcacheWritebackInvalidateRange(void *data, SceSize size);

sceKernelCpuDcacheAndL2InvalidateRange

Version offset mode
3.60 0x51014B60 thumb
void sceKernelCpuDcacheAndL2InvalidateRange(void *data, SceSize size);

sceKernelCpuDcacheAndL2WritebackRange

Version offset mode
3.60 0x51014BD0 thumb
void sceKernelCpuDcacheAndL2WritebackRange(void *data, SceSize size);

sceKernelCpuSuspendIntr

Version offset mode
3.60 0x51014838 thumb
int sceKernelCpuSuspendIntr(int *addr);

sceKernelCpuResumeIntr

Version offset mode
3.60 0x51014864 thumb
int sceKernelCpuResumeIntr(int *addr, int prev_state);

vaddr_to_paddr_with_mode

Version offset mode
3.60 0x51014E3C thumb

same to sysmem 3.60 sub_81023308

int vaddr_to_paddr_with_mode(int mode, int a2, const void *VA, int *pPA, int a5);

sceSblAuthMgrOpen

Version offset mode
3.60 0x51016CF8 thumb
int sceSblAuthMgrOpen(int *ctx);

sceSblAuthMgrClose

Version offset mode
3.60 0x51016D48 thumb
int sceSblAuthMgrClose(int ctx);

sceSblAuthMgrAuthHeader

Version offset mode
3.60 0x51016D68 thumb
int sceSblAuthMgrAuthHeader(int ctx, void *pSelfHeader, SceSize SelfHeaderSize, SceSblSmCommContext130 *ctx130);

sceSblAuthMgrSetupAuthSegment

Version offset mode
3.60 0x51016E58 thumb
int sceSblAuthMgrSetupAuthSegment(int ctx,int segment_number);

sceSblAuthMgrAuthSegment

Version offset mode
3.60 0x51016E94 thumb
int sceSblAuthMgrAuthSegment(int ctx, void *buffer, SceSize len);

sceSblQafMgrIsAllowHost0Access

Version offset mode
3.60 0x51016FE0 thumb
int sceSblQafMgrIsAllowHost0Access(void);

sceSblACMgrIsDevelopmentMode

Version offset mode
3.60 0x510170C8 thumb
int sceSblACMgrIsDevelopmentMode(void);

sceSblAimgrIsGenuineVITA

Version offset mode
3.60 0x51017248 thumb
int sceSblAimgrIsGenuineVITA(void);

get_module_object

Version offset mode
3.60 0x51017648 thumb
SceModuleObject *get_module_object(SceUID modid);

initialize_module_class

Version offset mode
3.60 0x51017680 thumb

sceKernelLoadModule

Version offset mode
3.60 0x51017930 thumb
SceUID sceKernelLoadModule(const char *path, int flags, void *option);

sceKernelLoadModuleForPidInternal

Version offset mode
3.60 0x51017830 thumb

don't have flags check

SceUID sceKernelLoadModuleForPidInternal(SceUID pid, const char *path, int flags, void *option);

sceSdifGetSdContextGlobal

Version offset mode
3.60 0x5101A9F4 thumb
void *sceSdifGetSdContextGlobal(int type);

sceSdifInitializeMmcDevice

Version offset mode
3.60 0x5101D7D0 thumb
int sceSdifInitializeMmcDevice(int sd_ctx_index, void **result);

sceSdifInitializeSdDevice

Version offset mode
3.60 0x5101D820 thumb
int sceSdifInitializeSdDevice(int sd_ctx_index, void **result);

sceSdifReadSectorMmc

Version offset mode
3.60 0x5101C5C8 thumb
int sceSdifReadSectorMmc(void *part_ctx, SceSize sector_pos, void *data, SceSize sector_num);

sceSdifReadSectorSd

Version offset mode
3.60 0x5101E670 thumb
int sceSdifReadSectorSd(void *part_ctx, SceSize sector_pos, void *data, SceSize sector_num);