VirtualBox

Changeset 104322 in vbox for trunk


Ignore:
Timestamp:
Apr 12, 2024 3:18:43 PM (9 months ago)
Author:
vboxsync
Message:

VMM/IEM: Have a single TB prologue which serves as an entry point to the TB, bugref:10653

Location:
trunk/src/VBox/VMM
Files:
5 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/VMMAll/IEMAllN8veHlpA-arm64.S

    r104230 r104322  
    3232#include <iprt/asmdefs-arm.h>
    3333
     34#ifdef AssertCompile
     35# undef AssertCompile
     36#endif
     37#define AssertCompile(a_Expr)
     38#define INCLUDED_FROM_ARM64_ASSEMBLY
     39#include "IEMN8veRecompiler.h"
     40
     41#define IEM_HLP_FUNCTION_ALIGNMENT 0x20
    3442
    3543BEGINCODE
    3644
    3745.extern NAME(iemThreadedFunc_BltIn_LogCpuStateWorker)
     46
     47#ifdef IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
     48/**
     49 * This is the common prologue of a TB, saving all volatile registers
     50 * and creating the stack frame for saving temporary values.
     51 *
     52 * @param    pVCpu    (x0)      The cross-context vCPU structure pointer.
     53 * @param    pCpumCtx (x1)      The cross-context CPUM context structure pointer.
     54 * @param    pTbStart (x2)      The TB instruction start pointer.
     55 */
     56ALIGNCODE(IEM_HLP_FUNCTION_ALIGNMENT)
     57BEGINPROC_HIDDEN iemNativeTbEntry
     58# ifdef RT_OS_DARWIN
     59        pacibsp
     60# endif
     61        stp     x19, x20, [sp, #-IEMNATIVE_FRAME_SAVE_REG_SIZE]! /* Allocate space for saving registers and place x19+x20 at the bottom. */
     62        stp     x21, x22, [sp, #0x10]                            /* Save x21 thru x28 (SP remains unchanged). */
     63        stp     x23, x24, [sp, #0x20]
     64        stp     x25, x26, [sp, #0x30]
     65        stp     x27, x28, [sp, #0x40]
     66        stp     x29, x30, [sp, #0x50]                            /* Save the BP and LR (ret address) registers at the top of the frame. */
     67        add     x29, sp, #(IEMNATIVE_FRAME_SAVE_REG_SIZE - 16)   /* Set BP to point to the old BP stack address */
     68        sub     sp, sp, #IEMNATIVE_FRAME_VAR_SIZE                /* Allocate the variable area from SP. */
     69        mov     IEMNATIVE_REG_FIXED_PVMCPU_ASM,   x0
     70        mov     IEMNATIVE_REG_FIXED_PCPUMCTX_ASM, x1
     71# ifdef VBOX_WITH_IEM_NATIVE_RECOMPILER_LONGJMP
     72        str     x29, [IEMNATIVE_REG_FIXED_PVMCPU_ASM, #0x7c8]    /* Save the frame pointer to pvTbFramePointerR3 */ /** @todo Get rid of this hardcoded assumption */
     73# endif
     74        /*
     75         * Everything is done, jump to the start of the TB.
     76         */
     77        br      x2
     78#endif
     79
    3880
    3981/**
     
    5395 *       it ourselves, I think.
    5496 */
     97ALIGNCODE(IEM_HLP_FUNCTION_ALIGNMENT)
    5598BEGINPROC_HIDDEN iemNativeTbLongJmp
    5699        /*
     
    81124 * so the impact of inserting LogCpuState is minimal to the other TB code.
    82125 */
     126ALIGNCODE(IEM_HLP_FUNCTION_ALIGNMENT)
    83127BEGINPROC_HIDDEN iemNativeHlpAsmSafeWrapLogCpuState
    84128#ifdef RT_OS_DARWIN
  • trunk/src/VBox/VMM/VMMAll/IEMAllN8veHlpA.asm

    r103376 r104322  
    3232%include "VBox/asmdefs.mac"
    3333
     34;; @todo r=aeichner The following is copied from IEMInternal.h
     35;%define VBOX_WITH_IEM_NATIVE_RECOMPILER_LONGJMP - not enabled right now on amd64
     36
     37;; @todo r=aeichner The following defines are copied from IEMN8veRecompiler.h
     38
     39; /** @def IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
     40;  * Enables having only a single prologue for native TBs. */
     41%define IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
     42
     43; /** An stack alignment adjustment (between non-volatile register pushes and
     44;  *  the stack variable area, so the latter better aligned). */
     45%define IEMNATIVE_FRAME_ALIGN_SIZE              8
     46
     47; /** The size of the area for stack variables and spills and stuff.
     48; * @note This limit is duplicated in the python script(s).  We add 0x40 for
     49; *       alignment padding. */
     50%define IEMNATIVE_FRAME_VAR_SIZE                (0xc0 + 0x40)
     51
     52; This needs to correspond to IEMNATIVE_REG_FIXED_PVMCPU in IEMN8veRecompiler.h
     53%define IEMNATIVE_REG_FIXED_PVMCPU_ASM          xBX
     54
     55; /** Number of stack arguments slots for calls made from the frame. */
     56%ifdef RT_OS_WINDOWS
     57%define IEMNATIVE_FRAME_STACK_ARG_COUNT         4
     58%else
     59%define IEMNATIVE_FRAME_STACK_ARG_COUNT         2
     60%endif
     61; /** Number of any shadow arguments (spill area) for calls we make. */
     62%ifdef RT_OS_WINDOWS
     63%define IEMNATIVE_FRAME_SHADOW_ARG_COUNT        4
     64%else
     65%define IEMNATIVE_FRAME_SHADOW_ARG_COUNT        0
     66%endif
     67
    3468
    3569BEGINCODE
     
    3771extern NAME(iemThreadedFunc_BltIn_LogCpuStateWorker)
    3872extern NAME(iemNativeHlpCheckTlbLookup)
     73
     74%ifdef IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
     75;;
     76; This is the common prologue of a TB, saving all volatile registers
     77; and creating the stack frame for saving temporary values.
     78;
     79; @param    pVCpu    (gcc:rdi, msc:rcx)      The cross-context vCPU structure pointer.
     80; @param    pTbStart (gcc:rsi, msc:rdx)      The TB instruction start pointer.
     81;
     82BEGINPROC   iemNativeTbEntry
     83        push rbp
     84        mov rbp, rsp
     85        push rbx
     86%ifdef ASM_CALL64_MSC
     87        mov IEMNATIVE_REG_FIXED_PVMCPU_ASM, rcx
     88        push rsi
     89        push rdi
     90%else
     91        mov IEMNATIVE_REG_FIXED_PVMCPU_ASM, rdi
     92%endif
     93        push r12
     94        push r13
     95        push r14
     96        push r15
     97%ifdef VBOX_WITH_IEM_NATIVE_RECOMPILER_LONGJMP
     98%error "Port me"
     99%endif
     100        sub rsp,  IEMNATIVE_FRAME_ALIGN_SIZE \
     101                + IEMNATIVE_FRAME_VAR_SIZE \
     102                + IEMNATIVE_FRAME_STACK_ARG_COUNT * 8 \
     103                + IEMNATIVE_FRAME_SHADOW_ARG_COUNT * 8 \
     104
     105%ifdef ASM_CALL64_MSC
     106        jmp rdx
     107%else
     108        jmp rsi
     109%endif
     110ENDPROC     iemNativeTbEntry
     111%endif
    39112
    40113
  • trunk/src/VBox/VMM/VMMAll/IEMAllN8veRecompiler.cpp

    r104283 r104322  
    64026402
    64036403
     6404#ifndef IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
    64046405/**
    64056406 * Emits a standard prolog.
     
    65156516    return off;
    65166517}
     6518#endif
    65176519
    65186520
     
    91109112    IEMNATIVE_TRY_SETJMP(pReNative, rc)
    91119113    {
     9114#ifndef IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
    91129115        /*
    91139116         * Emit prolog code (fixed).
    91149117         */
    91159118        off = iemNativeEmitProlog(pReNative, off);
     9119#endif
    91169120
    91179121        /*
  • trunk/src/VBox/VMM/VMMAll/IEMAllThrdRecompiler.cpp

    r104321 r104322  
    26892689        iemThreadedLogCurInstr(pVCpu, "EXn", 0);
    26902690# endif
    2691 # ifdef RT_ARCH_AMD64
     2691
     2692# ifndef IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
     2693#  ifdef RT_ARCH_AMD64
    26922694        VBOXSTRICTRC const rcStrict = ((PFNIEMTBNATIVE)pTb->Native.paInstructions)(pVCpu);
     2695#  else
     2696        VBOXSTRICTRC const rcStrict = ((PFNIEMTBNATIVE)pTb->Native.paInstructions)(pVCpu, &pVCpu->cpum.GstCtx);
     2697#  endif
    26932698# else
    2694         VBOXSTRICTRC const rcStrict = ((PFNIEMTBNATIVE)pTb->Native.paInstructions)(pVCpu, &pVCpu->cpum.GstCtx);
     2699#  ifdef VBOX_WITH_IEM_NATIVE_RECOMPILER_LONGJMP
     2700        AssertCompileMemberOffset(VMCPUCC, iem.s.pvTbFramePointerR3, 0x7c8); /* This is assumed in iemNativeTbEntry */
     2701#  endif
     2702#  ifdef RT_ARCH_AMD64
     2703        VBOXSTRICTRC const rcStrict = iemNativeTbEntry(pVCpu, (uintptr_t)pTb->Native.paInstructions);
     2704#  else
     2705        VBOXSTRICTRC const rcStrict = iemNativeTbEntry(pVCpu, &pVCpu->cpum.GstCtx, (uintptr_t)pTb->Native.paInstructions);
     2706#  endif
    26952707# endif
     2708
    26962709# ifdef VBOX_WITH_IEM_NATIVE_RECOMPILER_LONGJMP
    26972710        pVCpu->iem.s.pvTbFramePointerR3 = NULL;
  • trunk/src/VBox/VMM/include/IEMN8veRecompiler.h

    r104274 r104322  
    6868/** Always count instructions for now. */
    6969# define IEMNATIVE_WITH_INSTRUCTION_COUNTING
     70#endif
     71
     72/** @def IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
     73 * Enables having only a single prologue for native TBs. */
     74#if 1 || defined(DOXYGEN_RUNNING)
     75# define IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
    7076#endif
    7177
     
    199205#elif defined(RT_ARCH_ARM64) || defined(DOXYGEN_RUNNING)
    200206# define IEMNATIVE_REG_FIXED_PVMCPU         ARMV8_A64_REG_X28
     207# define IEMNATIVE_REG_FIXED_PVMCPU_ASM     x28
    201208# define IEMNATIVE_REG_FIXED_PCPUMCTX       ARMV8_A64_REG_X27
     209# define IEMNATIVE_REG_FIXED_PCPUMCTX_ASM   x27
    202210# define IEMNATIVE_REG_FIXED_TMP0           ARMV8_A64_REG_X15
    203211# if defined(IEMNATIVE_WITH_DELAYED_PC_UPDATING) && 0 /* debug the updating with a shadow RIP. */
     
    417425
    418426
     427/** @todo r=aeichner Can this be made prettier? */
     428#ifndef INCLUDED_FROM_ARM64_ASSEMBLY
     429
    419430/** Native code generator label types. */
    420431typedef enum
     
    24802491
    24812492
     2493#ifdef IEMNATIVE_WITH_RECOMPILER_PROLOGUE_SINGLETON
     2494# ifdef RT_ARCH_AMD64
     2495extern "C" IEM_DECL_NATIVE_HLP_DEF(VBOXSTRICTRC, iemNativeTbEntry, (PVMCPUCC pVCpu, uintptr_t pTbInsn));
     2496# elif defined(RT_ARCH_ARM64)
     2497extern "C" IEM_DECL_NATIVE_HLP_DEF(VBOXSTRICTRC, iemNativeTbEntry, (PVMCPUCC pVCpu, PCPUMCTX pCpumCtx, uintptr_t pTbInsn));
     2498# endif
     2499#endif
     2500
     2501#endif /* !INCLUDED_FROM_ARM64_ASSEMBLY */
     2502
    24822503/** @} */
    24832504
Note: See TracChangeset for help on using the changeset viewer.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette