1

iOS でジェイルブレイクされたアプリを開発していますが、呼び出し時に errno 22 が返されます

mprotect(p, 1024, PROT_READ | PROT_EXEC)

errno 22 は無効な引数を意味しますが、何が問題なのかわかりません。p をページ サイズの倍数になるように調整し、mprotect を呼び出す前に以前にメモリを割り当てました。

これが私のコードとサンプル出力です

#define PAGESIZE 4096

FILE * pFile;
pFile = fopen ("log.txt","w");

uint32_t code[] = {
    0xe2800001, // add  r0, r0, #1
    0xe12fff1e, // bx   lr
};

fprintf(pFile, "Before Execution\n");

p = (uint32_t *)malloc(1024+PAGESIZE-1);

if (!p) {
    fprintf(pFile, "Couldn't malloc(1024)");
    perror("Couldn't malloc(1024)");
    exit(errno);
}

fprintf(pFile, "Malloced to %p\n", p);

p = (uint32_t *)(((uintptr_t)p + PAGESIZE-1) & ~(PAGESIZE-1));

fprintf(pFile, "Moved pointer to %p\n", p);

fprintf(pFile, "Before Compiling\n");

// copy instructions to function
p[0] = code[0];
p[1] = code[1];

fprintf(pFile, "After Compiling\n");

if (mprotect(p, 1024, PROT_READ | PROT_EXEC)) {
    int err = errno;
    fprintf(pFile, "Couldn't mprotect2: %i\n", errno);
    perror("Couldn't mprotect");
    exit(errno);
}

そして出力:

Before Execution
Malloced to 0x13611ec00
Moved pointer 0x13611f000
Before Compiling
After Compiling
Couldn't mprotect2: 22
4

1 に答える 1

0

posix_memalign() を使用してこれを修正しました。ポインターをページサイズに正しく合わせていなかったことが判明しました

于 2015-12-08T20:43:40.593 に答える