X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/2d21ac55c334faf3a56e5634905ed6987fc787d4..440d4c6cfad24426bfddca7518f16c17f4e443f7:/osfmk/kern/page_decrypt.c diff --git a/osfmk/kern/page_decrypt.c b/osfmk/kern/page_decrypt.c index f416dc105..9914fe9d0 100644 --- a/osfmk/kern/page_decrypt.c +++ b/osfmk/kern/page_decrypt.c @@ -26,49 +26,41 @@ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ */ +#include #include #include #include -/*#include */ -extern int hz; /* system clock's frequency */ - -/* #include */ -extern int tsleep(void *chan, int pri, const char *wmesg, int timo); - -/* #include */ -#define PZERO 22 /* No longer magic, shouldn't be here. XXX */ - -static int _dsmos_wait_for_callback(const void*,void*); - -static dsmos_page_transform_hook_t dsmos_hook = _dsmos_wait_for_callback; - -int -_dsmos_wait_for_callback(const void* from, void *to) -{ -/* printf("%s\n", __FUNCTION__); */ - while (dsmos_hook == NULL || dsmos_hook == _dsmos_wait_for_callback) - tsleep(&dsmos_hook, PZERO, "dsmos", hz / 10); - - return (*dsmos_hook) (from, to); -} +static dsmos_page_transform_hook_t dsmos_hook = NULL; void dsmos_page_transform_hook(dsmos_page_transform_hook_t hook) { -/* printf("%s\n", __FUNCTION__); */ + printf("DSMOS has arrived\n"); /* set the hook now - new callers will run with it */ dsmos_hook = hook; } int -dsmos_page_transform(const void* from, void *to) +dsmos_page_transform(const void* from, void *to, unsigned long long src_offset, void *ops) { -/* printf("%s\n", __FUNCTION__); */ - if (dsmos_hook == NULL) - return KERN_FAILURE; - return (*dsmos_hook) (from, to); + static boolean_t first_wait = TRUE; + + if (dsmos_hook == NULL) { + if (first_wait) { + first_wait = FALSE; + printf("Waiting for DSMOS...\n"); + } + return KERN_ABORTED; + } + return (*dsmos_hook) (from, to, src_offset, ops); } + +text_crypter_create_hook_t text_crypter_create=NULL; +void text_crypter_create_hook_set(text_crypter_create_hook_t hook) +{ + text_crypter_create=hook; +}