VirtualBox

Changeset 67106 in vbox for trunk/src/VBox


Ignore:
Timestamp:
May 25, 2017 10:58:59 PM (8 years ago)
Author:
vboxsync
Message:

bs3-cpu-generated-1: cleanups

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/VBox/ValidationKit/bootsectors/bs3-cpu-generated-1-template.c

    r67105 r67106  
    21212121{
    21222122    unsigned off;
    2123     if (iEncoding == 0)
    2124     {
    2125         off = Bs3Cg1InsertOpcodes(pThis, Bs3Cg1InsertReqPrefix(pThis, 0));
    2126         pThis->cbCurInstr = off;
    2127     }
    2128     else
    2129         return 0;
     2123    switch (iEncoding)
     2124    {
     2125        case 0:
     2126            off = Bs3Cg1InsertOpcodes(pThis, Bs3Cg1InsertReqPrefix(pThis, 0));
     2127            pThis->cbCurInstr = off;
     2128            break;
     2129        default:
     2130            return 0;
     2131    }
    21302132    return iEncoding + 1;
    21312133}
     
    21352137{
    21362138    unsigned off;
    2137     if (iEncoding == 0)
    2138     {
    2139         off = Bs3Cg1InsertOpcodes(pThis, Bs3Cg1InsertReqPrefix(pThis, 0));
    2140         pThis->aOperands[1].off = (uint8_t)off;
    2141         pThis->abCurInstr[off++] = 0xff;
    2142         pThis->cbCurInstr = off;
    2143     }
    2144     else
    2145         return 0;
     2139    switch (iEncoding)
     2140    {
     2141        case 0:
     2142            off = Bs3Cg1InsertOpcodes(pThis, Bs3Cg1InsertReqPrefix(pThis, 0));
     2143            pThis->aOperands[1].off  = (uint8_t)off;
     2144            pThis->abCurInstr[off++] = 0xff;
     2145            pThis->cbCurInstr        = off;
     2146            break;
     2147        default:
     2148            return 0;
     2149    }
    21462150    return iEncoding + 1;
    21472151}
     
    21512155{
    21522156    unsigned off;
    2153     if (iEncoding == 0)
    2154     {
    2155         off = Bs3Cg1InsertOpcodes(pThis, Bs3Cg1InsertReqPrefix(pThis, 0));
    2156         pThis->aOperands[1].off = (uint8_t)off;
    2157         if (BS3_MODE_IS_16BIT_CODE(pThis->bMode))
    2158         {
    2159             *(uint16_t *)&pThis->abCurInstr[off] = UINT16_MAX;
    2160             off += 2;
    2161             pThis->aOperands[0].cbOp = 2;
    2162             pThis->aOperands[1].cbOp = 2;
    2163             pThis->cbOperand         = 2;
    2164         }
    2165         else
    2166         {
     2157    unsigned cbOp;
     2158    switch (iEncoding)
     2159    {
     2160        case 0:
     2161            off = Bs3Cg1InsertOpcodes(pThis, Bs3Cg1InsertReqPrefix(pThis, 0));
     2162            pThis->aOperands[1].off = (uint8_t)off;
     2163            cbOp = pThis->cbOpDefault;
     2164            if (cbOp == 2)
     2165                *(uint16_t *)&pThis->abCurInstr[off] = UINT16_MAX;
     2166            else
     2167                *(uint32_t *)&pThis->abCurInstr[off] = UINT32_MAX;
     2168            off += cbOp;
     2169            pThis->aOperands[0].cbOp = cbOp;
     2170            pThis->aOperands[1].cbOp = cbOp;
     2171            pThis->cbOperand         = cbOp;
     2172            break;
     2173        case 1:
     2174            if ((g_uBs3CpuDetected & BS3CPU_TYPE_MASK) < BS3CPU_80386)
     2175                return 0;
     2176            pThis->abCurInstr[0] = P_OZ;
     2177            off = Bs3Cg1InsertOpcodes(pThis, Bs3Cg1InsertReqPrefix(pThis, 1));
     2178            pThis->aOperands[1].off = (uint8_t)off;
     2179            cbOp = pThis->cbOpOvrd66;
     2180            if (cbOp == 2)
     2181                *(uint16_t *)&pThis->abCurInstr[off] = UINT16_MAX;
     2182            else
     2183                *(uint32_t *)&pThis->abCurInstr[off] = UINT32_MAX;
     2184            off += cbOp;
     2185            pThis->aOperands[0].cbOp = cbOp;
     2186            pThis->aOperands[1].cbOp = cbOp;
     2187            pThis->cbOperand         = cbOp;
     2188            iEncoding += !BS3CG1_IS_64BIT_TARGET(pThis) ? 1 : 0;
     2189            break;
     2190        case 2:
     2191            off = Bs3Cg1InsertReqPrefix(pThis, 0);
     2192            pThis->abCurInstr[off++] = REX_W___;
     2193            off = Bs3Cg1InsertOpcodes(pThis, off);
     2194            pThis->aOperands[1].off = (uint8_t)off;
    21672195            *(uint32_t *)&pThis->abCurInstr[off] = UINT32_MAX;
    21682196            off += 4;
    2169             pThis->aOperands[0].cbOp = 4;
     2197            pThis->aOperands[0].cbOp = 8;
    21702198            pThis->aOperands[1].cbOp = 4;
    2171             pThis->cbOperand         = 4;
    2172         }
    2173     }
    2174     else if (iEncoding == 1 && (g_uBs3CpuDetected & BS3CPU_TYPE_MASK) >= BS3CPU_80386)
    2175     {
    2176         pThis->abCurInstr[0] = P_OZ;
    2177         off = Bs3Cg1InsertOpcodes(pThis, Bs3Cg1InsertReqPrefix(pThis, 1));
    2178         pThis->aOperands[1].off = (uint8_t)off;
    2179         if (!BS3_MODE_IS_16BIT_CODE(pThis->bMode))
    2180         {
    2181             *(uint16_t *)&pThis->abCurInstr[off] = UINT16_MAX;
    2182             off += 2;
    2183             pThis->aOperands[0].cbOp = 2;
    2184             pThis->aOperands[1].cbOp = 2;
    2185             pThis->cbOperand         = 2;
    2186         }
    2187         else
    2188         {
    2189             *(uint32_t *)&pThis->abCurInstr[off] = UINT32_MAX;
    2190             off += 4;
    2191             pThis->aOperands[0].cbOp = 4;
    2192             pThis->aOperands[1].cbOp = 4;
    2193             pThis->cbOperand         = 4;
    2194         }
    2195     }
    2196     else if (iEncoding == 2 && BS3CG1_IS_64BIT_TARGET(pThis))
    2197     {
    2198         off = Bs3Cg1InsertReqPrefix(pThis, 0);
    2199         pThis->abCurInstr[off++] = REX_W___;
    2200         off = Bs3Cg1InsertOpcodes(pThis, off);
    2201         pThis->aOperands[1].off = (uint8_t)off;
    2202         *(uint32_t *)&pThis->abCurInstr[off] = UINT32_MAX;
    2203         off += 4;
    2204         pThis->aOperands[0].cbOp = 8;
    2205         pThis->aOperands[1].cbOp = 4;
    2206         pThis->cbOperand         = 8;
    2207     }
    2208     else
    2209         return 0;
     2199            pThis->cbOperand         = 8;
     2200            break;
     2201        default:
     2202            return 0;
     2203
     2204            /* IMAGE PADDING - workaround for "rd err" - remove later! */
     2205        case 4:
     2206            ASMHalt();
     2207            ASMHalt();
     2208            ASMHalt();
     2209            return 0;
     2210
     2211    }
    22102212    pThis->cbCurInstr = off;
    22112213    return iEncoding + 1;
     
    35323534{
    35333535    pThis->bAlignmentXcpt = UINT8_MAX;
    3534     pThis->uVexL = UINT8_MAX;
     3536    pThis->uVexL          = UINT8_MAX;
    35353537    if (pThis->pfnEncoder)
    35363538        return pThis->pfnEncoder(pThis, iEncoding);
    35373539
    3538     switch (pThis->enmEncoding)
    3539     {
    3540         case BS3CG1ENC_FIXED:
    3541             return Bs3Cg1EncodeNext_FIXED(pThis, iEncoding);
    3542         case BS3CG1ENC_FIXED_AL_Ib:
    3543             return Bs3Cg1EncodeNext_FIXED_AL_Ib(pThis, iEncoding);
    3544         case BS3CG1ENC_FIXED_rAX_Iz:
    3545             return Bs3Cg1EncodeNext_FIXED_rAX_Iz(pThis, iEncoding);
    3546 
    3547         /*
    3548          * VEX stuff
    3549          */
    3550 #ifdef BS3CG1_WITH_VEX
    3551         case BS3CG1ENC_VEX_MODRM_VssZx_WO_Md:
    3552             return Bs3Cg1EncodeNext_VEX_MODRM_VsomethingWO_Msomething_Wip_Lig_OR_ViceVersa(pThis, iEncoding);
    3553 
    3554 #endif /* BS3CG1_WITH_VEX */
    3555 
    3556         default:
    3557             Bs3TestFailedF("Internal error! BS3CG1ENC_XXX = %u not implemented", pThis->enmEncoding);
    3558             break;
    3559     }
    3560 
    3561 
     3540    Bs3TestFailedF("Internal error! BS3CG1ENC_XXX = %u not implemented", pThis->enmEncoding);
    35623541    return iEncoding;
    35633542}
     
    40103989        case BS3CG1ENC_MODRM_Mq_WO_Vq:
    40113990        case BS3CG1ENC_MODRM_Mq_WO_VqHi:
    4012             pThis->pfnEncoder                  = Bs3Cg1EncodeNext_MODRM_Msomething_Vsomething_OR_ViceVersa;
    4013             pThis->iRmOp                       = 0;
    4014             pThis->iRegOp                      = 1;
    4015             pThis->aOperands[0].cbOp           = 8;
    4016             pThis->aOperands[1].cbOp           = 8;
    4017             pThis->aOperands[0].enmLocation    = BS3CG1OPLOC_MEM_WO;
    4018             pThis->aOperands[0].enmLocationMem = BS3CG1OPLOC_MEM_WO;
    4019             pThis->aOperands[1].enmLocation    = BS3CG1OPLOC_CTX;
    4020             pThis->aOperands[1].idxFieldBase   = pThis->enmEncoding == BS3CG1ENC_MODRM_Mq_WO_Vq
    4021                                                ? BS3CG1DST_XMM0_LO : BS3CG1DST_XMM0_HI;
     3991            pThis->pfnEncoder                   = Bs3Cg1EncodeNext_MODRM_Msomething_Vsomething_OR_ViceVersa;
     3992            pThis->iRmOp                        = 0;
     3993            pThis->iRegOp                       = 1;
     3994            pThis->aOperands[0].cbOp            = 8;
     3995            pThis->aOperands[1].cbOp            = 8;
     3996            pThis->aOperands[0].enmLocation     = BS3CG1OPLOC_MEM_WO;
     3997            pThis->aOperands[0].enmLocationMem  = BS3CG1OPLOC_MEM_WO;
     3998            pThis->aOperands[1].enmLocation     = BS3CG1OPLOC_CTX;
     3999            pThis->aOperands[1].idxFieldBase    = pThis->enmEncoding == BS3CG1ENC_MODRM_Mq_WO_Vq
     4000                                                ? BS3CG1DST_XMM0_LO : BS3CG1DST_XMM0_HI;
    40224001            break;
    40234002
    40244003        case BS3CG1ENC_MODRM_Mps_WO_Vps:
    40254004        case BS3CG1ENC_MODRM_Mpd_WO_Vpd:
    4026             pThis->pfnEncoder                  = Bs3Cg1EncodeNext_MODRM_Msomething_Vsomething_OR_ViceVersa;
    4027             pThis->iRmOp                       = 0;
    4028             pThis->iRegOp                      = 1;
    4029             pThis->aOperands[0].cbOp           = 16;
    4030             pThis->aOperands[1].cbOp           = 16;
    4031             pThis->aOperands[0].enmLocation    = BS3CG1OPLOC_MEM_WO;
    4032             pThis->aOperands[1].enmLocation    = BS3CG1OPLOC_CTX;
    4033             pThis->aOperands[1].idxFieldBase   = BS3CG1DST_XMM0;
     4005            pThis->pfnEncoder                   = Bs3Cg1EncodeNext_MODRM_Msomething_Vsomething_OR_ViceVersa;
     4006            pThis->iRmOp                        = 0;
     4007            pThis->iRegOp                       = 1;
     4008            pThis->aOperands[0].cbOp            = 16;
     4009            pThis->aOperands[1].cbOp            = 16;
     4010            pThis->aOperands[0].enmLocation     = BS3CG1OPLOC_MEM_WO;
     4011            pThis->aOperands[1].enmLocation     = BS3CG1OPLOC_CTX;
     4012            pThis->aOperands[1].idxFieldBase    = BS3CG1DST_XMM0;
    40344013            break;
    40354014
    40364015        case BS3CG1ENC_FIXED:
    4037             /* nothing to do here */
     4016            pThis->pfnEncoder                   = Bs3Cg1EncodeNext_FIXED;
    40384017            break;
    40394018
    40404019        case BS3CG1ENC_FIXED_AL_Ib:
    4041             pThis->aOperands[0].cbOp           = 1;
    4042             pThis->aOperands[1].cbOp           = 1;
    4043             pThis->aOperands[0].enmLocation    = BS3CG1OPLOC_CTX;
    4044             pThis->aOperands[1].enmLocation    = BS3CG1OPLOC_IMM;
    4045             pThis->aOperands[0].idxField       = BS3CG1DST_AL;
    4046             pThis->aOperands[1].idxField       = BS3CG1DST_INVALID;
     4020            pThis->pfnEncoder                   = Bs3Cg1EncodeNext_FIXED_AL_Ib;
     4021            pThis->aOperands[0].cbOp            = 1;
     4022            pThis->aOperands[1].cbOp            = 1;
     4023            pThis->aOperands[0].enmLocation     = BS3CG1OPLOC_CTX;
     4024            pThis->aOperands[1].enmLocation     = BS3CG1OPLOC_IMM;
     4025            pThis->aOperands[0].idxField        = BS3CG1DST_AL;
     4026            pThis->aOperands[1].idxField        = BS3CG1DST_INVALID;
    40474027            break;
    40484028
    40494029        case BS3CG1ENC_FIXED_rAX_Iz:
    4050             pThis->aOperands[0].cbOp           = 2;
    4051             pThis->aOperands[1].cbOp           = 2;
    4052             pThis->aOperands[0].enmLocation    = BS3CG1OPLOC_CTX;
    4053             pThis->aOperands[1].enmLocation    = BS3CG1OPLOC_IMM;
    4054             pThis->aOperands[0].idxField       = BS3CG1DST_OZ_RAX;
    4055             pThis->aOperands[1].idxField       = BS3CG1DST_INVALID;
     4030            pThis->pfnEncoder                   = Bs3Cg1EncodeNext_FIXED_rAX_Iz;
     4031            pThis->aOperands[0].cbOp            = 2;
     4032            pThis->aOperands[1].cbOp            = 2;
     4033            pThis->aOperands[0].enmLocation     = BS3CG1OPLOC_CTX;
     4034            pThis->aOperands[1].enmLocation     = BS3CG1OPLOC_IMM;
     4035            pThis->aOperands[0].idxField        = BS3CG1DST_OZ_RAX;
     4036            pThis->aOperands[1].idxField        = BS3CG1DST_INVALID;
    40564037            break;
    40574038
    40584039            /* Unused or invalid instructions mostly. */
    40594040        case BS3CG1ENC_MODRM_MOD_EQ_3:
    4060             pThis->pfnEncoder                  = Bs3Cg1EncodeNext_MODRM_MOD_EQ_3;
     4041            pThis->pfnEncoder                   = Bs3Cg1EncodeNext_MODRM_MOD_EQ_3;
    40614042            break;
    40624043        case BS3CG1ENC_MODRM_MOD_NE_3:
    4063             pThis->pfnEncoder                  = Bs3Cg1EncodeNext_MODRM_MOD_NE_3;
     4044            pThis->pfnEncoder                   = Bs3Cg1EncodeNext_MODRM_MOD_NE_3;
    40644045            break;
    40654046
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