Es ist sehr hacky und UNTRAGBAR, aber:
void sighandler (int signo, siginfo_t si, void *data) {
ucontext_t *uc = (ucontext_t *)data;
int instruction_length = /* the length of the "instruction" to skip */
uc->uc_mcontext.gregs[REG_RIP] += instruction_length;
}
Installieren Sie sighandler
so:
struct sigaction sa, osa;
sa.sa_flags = SA_ONSTACK | SA_RESTART | SA_SIGINFO;
sa.sa_sigaction = sighandler;
sigaction(SIGILL, &sa, &osa);
Das könnte funktionieren, wenn Sie wissen, wie weit Sie überspringen müssen (und es ist ein Intel-Proc) :-)