VirtualBox

Changeset 60445 in vbox for trunk/src/VBox


Ignore:
Timestamp:
Apr 12, 2016 8:35:53 AM (9 years ago)
Author:
vboxsync
Message:

bs3-cpu-basic-2: started on sidt.

Location:
trunk/src/VBox/ValidationKit/bootsectors
Files:
3 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/ValidationKit/bootsectors/bs3-cpu-basic-2-c.c

    r60319 r60445  
    4040//BS3TESTMODE_PROTOTYPES_CMN(bs3CpuBasic2_iret);
    4141BS3TESTMODE_PROTOTYPES_MODE(bs3CpuBasic2_iret);
     42BS3TESTMODE_PROTOTYPES_MODE(bs3CpuBasic2_sidt);
    4243
    4344
     
    4849{
    4950    //BS3TESTMODEENTRY_MODE("tss / gate / esp", bs3CpuBasic2_TssGateEsp),
    50     BS3TESTMODEENTRY_MODE("raise xcpt #1", bs3CpuBasic2_RaiseXcpt1),
     51    //BS3TESTMODEENTRY_MODE("raise xcpt #1", bs3CpuBasic2_RaiseXcpt1),
    5152    //BS3TESTMODEENTRY_CMN("iret", bs3CpuBasic2_iret),
    5253    //BS3TESTMODEENTRY_MODE("iret", bs3CpuBasic2_iret),
     54    BS3TESTMODEENTRY_MODE("sidt", bs3CpuBasic2_sidt),
    5355};
    5456
  • trunk/src/VBox/ValidationKit/bootsectors/bs3-cpu-basic-2-template.c

    r60444 r60445  
    9494extern BS3_DECL(void) TMPL_NM(bs3CpuBasic2_Int83)(void);
    9595extern BS3_DECL(void) TMPL_NM(bs3CpuBasic2_ud2)(void);
     96extern BS3_DECL(void) TMPL_NM(bs3CpuBasic2_sidt_bx_ud2)(void);
     97extern BS3_DECL(void) TMPL_NM(bs3CpuBasic2_lidt_bx_ud2)(void);
    9698#ifndef DOXYGEN_RUNNING
    9799# define g_bs3CpuBasic2_ud2_FlatAddr BS3_DATA_NM(g_bs3CpuBasic2_ud2_FlatAddr)
     
    12971299}
    12981300
     1301
     1302#define bs3CpuBasic2_sidt_Common BS3_CMN_NM(bs3CpuBasic2_sidt_Common)
     1303void bs3CpuBasic2_sidt_Common(void)
     1304{
     1305    BS3TRAPFRAME        TrapCtx;
     1306    BS3REGCTX           Ctx;
     1307    BS3REGCTX           TmpCtx;
     1308    uint8_t             abBuf[16];
     1309    uint8_t BS3_FAR    *pbBuf = abBuf;
     1310
     1311    /* make sure they're allocated  */
     1312    Bs3MemZero(&Ctx, sizeof(Ctx));
     1313    Bs3MemZero(&TmpCtx, sizeof(TmpCtx));
     1314    Bs3MemZero(&TrapCtx, sizeof(TrapCtx));
     1315    Bs3MemZero(&abBuf, sizeof(abBuf));
     1316
     1317    /* Create a context, give this routine some more stack space, point the context
     1318       at our SIDT [xBX] + UD2 combo, and point DS:xBX at abBuf. */
     1319    Bs3RegCtxSave(&Ctx);
     1320    Ctx.rsp.u -= 0x80;
     1321    Ctx.rip.u  = (uintptr_t)BS3_FP_OFF(&TMPL_NM(bs3CpuBasic2_sidt_bx_ud2));
     1322# if TMPL_BITS == 32
     1323    g_uBs3TrapEipHint = Ctx.rip.u32;
     1324# endif
     1325    Ctx.rbx.u = BS3_FP_OFF(pbBuf);
     1326# if TMPL_BITS == 16
     1327    Ctx.ds    = BS3_FP_SEG(pbBuf);
     1328# endif
     1329
     1330    /*
     1331     * Check that it works at all.
     1332     */
     1333    Bs3MemZero(&abBuf, sizeof(abBuf));
     1334    Bs3TrapSetJmpAndRestore(&Ctx, &TrapCtx);
     1335    g_usBs3TestStep = 0;
     1336    //bs3CpuBasic2_CompareIntCtx1(&TrapCtx, &Ctx, 0x80 /*bXcpt*/);
     1337
     1338}
     1339
    12991340#endif /* once for each bitcount */
    13001341
     
    14541495}
    14551496
    1456 #endif
     1497#endif /* PE16 || PE32 */
    14571498
    14581499
     
    15241565
    15251566
    1526 
    1527 
    15281567BS3_DECL(uint8_t) TMPL_NM(bs3CpuBasic2_iret)(uint8_t bMode)
    15291568{
     
    15361575
    15371576
     1577BS3_DECL(uint8_t) TMPL_NM(bs3CpuBasic2_sidt)(uint8_t bMode)
     1578{
     1579    g_pszTestMode = TMPL_NM(g_szBs3ModeName);
     1580    g_bTestMode   = bMode;
     1581    g_f16BitSys   = BS3_MODE_IS_16BIT_SYS(TMPL_MODE);
     1582
     1583    BS3_ASSERT(bMode == TMPL_MODE);
     1584
     1585    /*
     1586     * Pass to common worker which is only compiled once per mode.
     1587     */
     1588    bs3CpuBasic2_sidt_Common();
     1589
     1590    /*
     1591     * Re-initialize the IDT.
     1592     */
     1593    TMPL_NM(Bs3TrapInit)();
     1594    return 0;
     1595}
     1596
     1597
    15381598#endif /* BS3_INSTANTIATING_MODE */
    15391599
  • trunk/src/VBox/ValidationKit/bootsectors/bs3-cpu-basic-2-template.mac

    r60295 r60445  
    8181BS3_PROC_BEGIN_MODE bs3CpuBasic2_Int80
    8282        int     80h
    83         ud2
     83.again: ud2
     84        jmp     .again
    8485BS3_PROC_END_MODE   bs3CpuBasic2_Int80
    8586
     
    8788BS3_PROC_BEGIN_MODE bs3CpuBasic2_Int81
    8889        int     81h
    89         ud2
     90.again: ud2
     91        jmp     .again
    9092BS3_PROC_END_MODE   bs3CpuBasic2_Int81
    9193
     
    9395BS3_PROC_BEGIN_MODE bs3CpuBasic2_Int82
    9496        int     82h
    95         ud2
     97.again: ud2
     98        jmp     .again
    9699BS3_PROC_END_MODE   bs3CpuBasic2_Int82
    97100
     
    99102BS3_PROC_BEGIN_MODE bs3CpuBasic2_Int83
    100103        int     83h
    101         ud2
     104.again: ud2
     105        jmp     .again
    102106BS3_PROC_END_MODE   bs3CpuBasic2_Int83
     107
     108
     109BS3_PROC_BEGIN_MODE bs3CpuBasic2_sidt_bx_ud2
     110        sidt    [xBX]
     111.again: ud2
     112        jmp     .again
     113BS3_PROC_END_MODE   bs3CpuBasic2_sidt_bx_ud2
     114
     115
     116BS3_PROC_BEGIN_MODE bs3CpuBasic2_lidt_bx_ud2
     117        lidt    [xBX]
     118.again: ud2
     119        jmp     .again
     120BS3_PROC_END_MODE   bs3CpuBasic2_lidt_bx_ud2
    103121
    104122
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