Enable instruction skipping for OpenBSD 3.4 on i386

This commit is contained in:
gbeauche 2005-03-23 22:00:06 +00:00
parent f2908fe7bf
commit 35e8c8c9cd

View File

@ -264,7 +264,7 @@ static void powerpc_decode_instruction(instruction_t *instruction, unsigned int
#define SIGSEGV_SKIP_INSTRUCTION ix86_skip_instruction #define SIGSEGV_SKIP_INSTRUCTION ix86_skip_instruction
#endif #endif
#endif #endif
#if defined(__FreeBSD__) #if defined(__FreeBSD__) || defined(__OpenBSD__)
#if (defined(i386) || defined(__i386__)) #if (defined(i386) || defined(__i386__))
#define SIGSEGV_FAULT_INSTRUCTION (((struct sigcontext *)scp)->sc_eip) #define SIGSEGV_FAULT_INSTRUCTION (((struct sigcontext *)scp)->sc_eip)
#define SIGSEGV_REGISTER_FILE ((unsigned long *)&(((struct sigcontext *)scp)->sc_edi)) /* EDI is the first GPR (even below EIP) in sigcontext */ #define SIGSEGV_REGISTER_FILE ((unsigned long *)&(((struct sigcontext *)scp)->sc_edi)) /* EDI is the first GPR (even below EIP) in sigcontext */
@ -737,6 +737,26 @@ enum {
#endif #endif
}; };
#endif #endif
#if defined(__OpenBSD__)
enum {
#if defined(__i386__)
// EDI is the first register we consider
#define OREG(REG) offsetof(struct sigcontext, sc_##REG)
#define DREG(REG) ((OREG(REG) - OREG(edi)) / 4)
X86_REG_EIP = DREG(eip), // 7
X86_REG_EAX = DREG(eax), // 6
X86_REG_ECX = DREG(ecx), // 5
X86_REG_EDX = DREG(edx), // 4
X86_REG_EBX = DREG(ebx), // 3
X86_REG_ESP = DREG(esp), // 10
X86_REG_EBP = DREG(ebp), // 2
X86_REG_ESI = DREG(esi), // 1
X86_REG_EDI = DREG(edi) // 0
#undef DREG
#undef OREG
#endif
};
#endif
#if defined(__sun__) #if defined(__sun__)
// Same as for Linux, need to check for x86-64 // Same as for Linux, need to check for x86-64
enum { enum {