X-Git-Url: https://git.saurik.com/apple/xnu.git/blobdiff_plain/b0d623f7f2ae71ed96e60569f61f9a9a27016e80..99c3a10404e5d1ef94397ab4df5a8b74711fc4d3:/osfmk/i386/asm64.h diff --git a/osfmk/i386/asm64.h b/osfmk/i386/asm64.h index 08afac97a..0f9213e7d 100644 --- a/osfmk/i386/asm64.h +++ b/osfmk/i386/asm64.h @@ -28,6 +28,7 @@ /* Helper macros for 64-bit mode switching */ +#if __i386__ /* * Long jump to 64-bit space from 32-bit compatibility mode. */ @@ -60,3 +61,32 @@ .code32 ;\ 4: +#else + +/* + * Long jump to 64-bit space from 32-bit compatibility mode. + * Effected, in fact, by a long return .. + * - we push the 64-bit kernel code selector KERNEL64_CS + * - call .+1 to get EIP on stack + * - adjust return address after lret + * - lret to return to next instruction but 64-bit mode. + */ +#define ENTER_64BIT_MODE() \ + push $KERNEL64_CS ;\ + call 1f ;\ +1: addl $(2f-1b), (%esp) ;\ + lret ;\ +2: .code64 + +/* + * Long jump to 32-bit compatibility mode from 64-bit space. + * Effected by long return similar to ENTER_64BIT_MODE. + */ +#define ENTER_COMPAT_MODE() \ + call 3f ;\ +3: addq $(4f-3b), (%rsp) ;\ + movl $KERNEL32_CS, 4(%rsp) ;\ + lret ;\ +4: .code32 + +#endif