VirtualBox

Changeset 48236 in vbox


Ignore:
Timestamp:
Sep 2, 2013 7:14:55 PM (11 years ago)
Author:
vboxsync
Message:

VMM: Use the CMOS for debugging 64-bit on 32-bit issue (VBOX_WITH_64ON32_CMOS_DEBUG, disabled ofc).

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

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/VMM/Makefile.kmk

    r48221 r48236  
    6565ifdef VBOX_WITH_64ON32_IDT
    6666 VMM_COMMON_DEFS += VBOX_WITH_64ON32_IDT
     67endif
     68ifdef VBOX_WITH_64ON32_CMOS_DEBUG
     69 VMM_COMMON_DEFS += VBOX_WITH_64ON32_CMOS_DEBUG
    6770endif
    6871
  • trunk/src/VBox/VMM/VMMR0/VMMR0.cpp

    r48201 r48236  
    115115#endif
    116116    LogFlow(("ModuleInit:\n"));
     117
     118#ifdef VBOX_WITH_64ON32_CMOS_DEBUG
     119    /*
     120     * Display the CMOS debug code.
     121     */
     122    ASMOutU8(0x72, 0x03);
     123    uint8_t bDebugCode = ASMInU8(0x73);
     124    LogRel(("CMOS Debug Code: %#x (%d)\n", bDebugCode, bDebugCode));
     125    RTLogComPrintf("CMOS Debug Code: %#x (%d)\n", bDebugCode, bDebugCode);
     126#endif
    117127
    118128    /*
  • trunk/src/VBox/VMM/VMMSwitcher/LegacyandAMD64.mac

    r48221 r48236  
    3030%define HM64ON32OP_HMRCSaveGuestDebug64 4
    3131%define HM64ON32OP_HMRCTestSwitcher64   5
     32
     33;;
     34; This macro is used for storing a debug code in a CMOS location.
     35;
     36; If we tripple fault or something, the debug code can be retrieved and we
     37; might have a clue as to where the problem occurred.  The code is currently
     38; using CMOS register 3 in the 2nd bank as this _seems_ to be unused on my
     39; Extreme4 X79 asrock mainboard.
     40;
     41; @param %1     The debug code (byte)
     42; @note Trashes AL.
     43;
     44%macro DEBUG_CMOS_TRASH_AL 1
     45%ifdef VBOX_WITH_64ON32_CMOS_DEBUG
     46    mov     al, 3
     47    out     72h, al
     48    mov     al, %1
     49    out     73h, al
     50    in      al, 73h
     51%endif
     52%endmacro
     53
     54;;
     55; Version of DEBUG_CMOS_TRASH_AL that saves AL on the stack and therefore
     56; doesn't trash any registers.
     57;
     58%macro DEBUG_CMOS_STACK64 1
     59%ifdef VBOX_WITH_64ON32_CMOS_DEBUG
     60    push    rax
     61    DEBUG_CMOS_TRASH_AL %1
     62    pop     rax
     63%endif
     64%endmacro
     65
     66;;
     67; Version of DEBUG_CMOS_TRASH_AL that saves AL on the stack and therefore
     68; doesn't trash any registers.
     69;
     70%macro DEBUG_CMOS_STACK32 1
     71%ifdef VBOX_WITH_64ON32_CMOS_DEBUG
     72    push    eax
     73    DEBUG_CMOS_TRASH_AL %1
     74    pop     eax
     75%endif
     76%endmacro
     77
    3278
    3379;; Stubs for making OS/2 compile (though, not work).
     
    113159    pushf
    114160    cli
     161    DEBUG_CMOS_STACK32 10h
    115162
    116163    ;
     
    151198
    152199gth_x2apic:
     200    ;DEBUG_CMOS_STACK32 7ch
    153201    push    eax                         ; save eax
    154202    push    ebx                         ; save it for fApicDisVectors
     
    191239
    192240    ; restore original flags
     241    ;DEBUG_CMOS_STACK32 7eh
    193242    popf
    194243    pop     ebp
     
    203252%endif
    204253
     254    ;DEBUG_CMOS_STACK32 7fh
    205255    ret
    206256
     
    399449
    400450    ; Load new gdt so we can do a far jump after going into 64 bits mode
     451    ;DEBUG_CMOS_STACK32 16h
    401452    lgdt    [edx + CPUMCPU.Hyper.gdtr]
    402453
     
    414465    mov     cr3, eax
    415466    DEBUG32_CHAR('?')
     467    DEBUG_CMOS_TRASH_AL 17h
    416468
    417469    ;;
     
    509561ALIGNCODE(16)
    510562GLOBALNAME ICEnterTarget
     563    DEBUG_CMOS_TRASH_AL 1ah
    511564    ; Load CPUM pointer into rdx
    512565    mov     rdx, [NAME(pCpumIC) wrt rip]
     
    716769    push    rbp
    717770    mov     rbp, rsp
     771    DEBUG_CMOS_STACK64 20h
    718772
    719773    ; Make sure VT-x instructions are allowed.
     
    815869    mov     eax, VMX_VMCS_HOST_FIELD_SS
    816870    vmwrite rax, rdx
     871
     872%if 0 ; Another experiment regarding tripple faults... Seems not to be necessary.
     873    sub     rsp, 16
     874    str     [rsp]
     875    movsx   rdx, word [rsp]
     876    mov     eax, VMX_VMCS_HOST_FIELD_TR
     877    vmwrite rax, rdx
     878    add     rsp, 16
     879%endif
    817880
    818881    sub     rsp, 16
     
    10781141    mov     rbp, rsp
    10791142    pushf
     1143    DEBUG_CMOS_STACK64 30h
    10801144
    10811145    ; Manual save and restore:
     
    11691233; */
    11701234BEGINPROC HMRCSaveGuestFPU64
     1235    DEBUG_CMOS_STACK64 40h
    11711236    mov     rax, cr0
    11721237    mov     rcx, rax                    ; save old CR0
     
    11891254; */
    11901255BEGINPROC HMRCSaveGuestDebug64
     1256    DEBUG_CMOS_STACK64 41h
    11911257    mov rax, dr0
    11921258    mov qword [rsi + CPUMCTX.dr + 0*8], rax
     
    12151281; */
    12161282BEGINPROC HMRCTestSwitcher64
     1283    DEBUG_CMOS_STACK64 42h
    12171284    mov eax, [rsp+8]
    12181285    ret
     
    14301497 %endif
    14311498
     1499 %if 1
     1500;; For debugging purposes.
     1501BEGINPROC vmm64On32DumpCmos
     1502    push    rax
     1503    push    rdx
     1504    push    rcx
     1505    push    rsi                         ; paranoia
     1506    push    rdi                         ; ditto
     1507    sub rsp, 16
     1508
     1509%if 0
     1510    mov     al, 3
     1511    out     72h, al
     1512    mov     al, 68h
     1513    out     73h, al
     1514%endif
     1515
     1516    COM64_S_NEWLINE
     1517    COM64_S_CHAR 'c'
     1518    COM64_S_CHAR 'm'
     1519    COM64_S_CHAR 'o'
     1520    COM64_S_CHAR 's'
     1521    COM64_S_CHAR '0'
     1522    COM64_S_CHAR ':'
     1523
     1524    xor     ecx, ecx
     1525.loop1:
     1526    mov     al, cl
     1527    out     70h, al
     1528    in      al, 71h
     1529    COM64_S_BYTE_REG eax
     1530    COM64_S_CHAR ' '
     1531    inc     ecx
     1532    cmp     ecx, 128
     1533    jb      .loop1
     1534
     1535    COM64_S_NEWLINE
     1536    COM64_S_CHAR 'c'
     1537    COM64_S_CHAR 'm'
     1538    COM64_S_CHAR 'o'
     1539    COM64_S_CHAR 's'
     1540    COM64_S_CHAR '1'
     1541    COM64_S_CHAR ':'
     1542    xor     ecx, ecx
     1543.loop2:
     1544    mov     al, cl
     1545    out     72h, al
     1546    in      al, 73h
     1547    COM64_S_BYTE_REG eax
     1548    COM64_S_CHAR ' '
     1549    inc     ecx
     1550    cmp     ecx, 128
     1551    jb      .loop2
     1552
     1553%if 0
     1554    COM64_S_NEWLINE
     1555    COM64_S_CHAR 'c'
     1556    COM64_S_CHAR 'm'
     1557    COM64_S_CHAR 'o'
     1558    COM64_S_CHAR 's'
     1559    COM64_S_CHAR '2'
     1560    COM64_S_CHAR ':'
     1561    xor     ecx, ecx
     1562.loop3:
     1563    mov     al, cl
     1564    out     74h, al
     1565    in      al, 75h
     1566    COM64_S_BYTE_REG eax
     1567    COM64_S_CHAR ' '
     1568    inc     ecx
     1569    cmp     ecx, 128
     1570    jb      .loop3
     1571
     1572    COM64_S_NEWLINE
     1573    COM64_S_CHAR 'c'
     1574    COM64_S_CHAR 'm'
     1575    COM64_S_CHAR 'o'
     1576    COM64_S_CHAR 's'
     1577    COM64_S_CHAR '3'
     1578    COM64_S_CHAR ':'
     1579    xor     ecx, ecx
     1580.loop4:
     1581    mov     al, cl
     1582    out     72h, al
     1583    in      al, 73h
     1584    COM64_S_BYTE_REG eax
     1585    COM64_S_CHAR ' '
     1586    inc     ecx
     1587    cmp     ecx, 128
     1588    jb      .loop4
     1589
     1590    COM64_S_NEWLINE
     1591%endif
     1592
     1593    add rsp, 16
     1594    pop     rdi
     1595    pop     rsi
     1596    pop     rcx
     1597    pop     rdx
     1598    pop     rax
     1599    ret
     1600ENDPROC   vmm64On32DumpCmos
     1601 %endif
     1602
    14321603%endif ; VBOX_WITH_64ON32_IDT
    14331604
     
    15681739GLOBALNAME ICExitTarget
    15691740    DEBUG32_CHAR('9')
     1741    ;DEBUG_CMOS_TRASH_AL 70h
    15701742
    15711743    ; load the hypervisor data selector into ds & es
     
    16461818
    16471819    ; store the return code in eax
     1820    DEBUG_CMOS_TRASH_AL 79h
    16481821    mov     eax, [edx + CPUMCPU.u32RetCode]
    16491822    retf
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