Changeset 46875 in vbox for trunk/src/VBox/VMM
- Timestamp:
- Jun 29, 2013 2:15:38 AM (11 years ago)
- Location:
- trunk/src/VBox/VMM/testcase/Instructions
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/VMM/testcase/Instructions/InstructionTestGen.py
r46856 r46875 583 583 % (oGen.needGRegMemSetup(cAddrBits, cbEffOp, iBaseReg = iBaseReg, offDisp = offDisp, 584 584 iIndexReg = iIndexReg, iScale = iScale),)); 585 oGen.write(' push %s\n' % (oGen.oTarget.asGRegs[iIndexReg],)); 585 586 oGen.write(' push %s\n' % (oGen.oTarget.asGRegs[iBaseReg],)); 586 oGen.write(' push %s\n' % (oGen.oTarget.asGRegs[iIndexReg],));587 587 return True; 588 588 … … 605 605 oGen.write(' call VBINSTST_NAME(Common_LoadKnownValues)\n'); 606 606 oGen.write(' mov %s, 0x%x\n' % (oGen.oTarget.asGRegs[iOp2X], uInput,)); 607 oGen.write(' push %s\n' % (oGen.oTarget.asGRegs[iOp2X],)); 607 if iOp1X != iOp2X: 608 oGen.write(' push %s\n' % (oGen.oTarget.asGRegs[iOp2X],)); 608 609 self.writeInstrGregGreg(cbEffOp, iOp1, iOp2, oGen); 609 610 oGen.pushConst(uResult); 610 oGen.write(' call VBINSTST_NAME(%s)\n' % (oGen.needGRegChecker(iOp1X, iOp2X ),));611 oGen.write(' call VBINSTST_NAME(%s)\n' % (oGen.needGRegChecker(iOp1X, iOp2X if iOp1X != iOp2X else None),)); 611 612 _ = cbMaxOp; 612 613 return True; … … 700 701 sChecker = oGen.needGRegChecker(iOp1, iBaseReg); 701 702 else: 703 if iIndexReg == iBaseReg and iScale == 1 and offDisp is not None and (offDisp & 1): 704 if offDisp < 0: offDisp += 1; 705 else: offDisp -= 1; 702 706 self.generateMemSetupReadByBaseAndScaledReg(oGen, cAddrBits, cbEffOp, iBaseReg, 703 707 iIndexReg, iScale, uInput, offDisp); … … 712 716 """ Generate all SIB variations for the given iOp1 (reg) value. """ 713 717 assert cAddrBits in [32, 64]; 714 for iBaseReg in range( len(oGen.oTarget.asGRegs)):715 for iIndexReg in range( len(oGen.oTarget.asGRegs)):718 for iBaseReg in range(oGen.oTarget.getGRegCount(cAddrBits / 8)): 719 for iIndexReg in range(oGen.oTarget.getGRegCount(cAddrBits / 8)): 716 720 if iBaseReg == 4 or iIndexReg == 4: # no RSP testing atm. 717 721 continue; 718 722 for iMod in [0, 1, 2]: 719 723 if iBaseReg == iOp1 and ((iBaseReg != 5 and iBaseReg != 13) or iMod != 0) and cAddrBits != cbMaxOp: 724 continue; # Don't know the high bit of the address ending up the result - skip it for now. 725 if iIndexReg == iOp1 and iIndexReg != 4 and cAddrBits != cbMaxOp: 720 726 continue; # Don't know the high bit of the address ending up the result - skip it for now. 721 727 for iScale in (1, 2, 4, 8): … … 746 752 747 753 # Register tests 748 if True:754 if False: 749 755 for cbEffOp in self.acbOpVars: 750 756 if cbEffOp > cbMaxOp: … … 777 783 778 784 # Memory test. 779 if False:785 if True: 780 786 for cbEffOp in self.acbOpVars: 781 787 if cbEffOp > cbMaxOp: … … 786 792 for cAddrBits in oGen.oTarget.getAddrModes(): 787 793 auInputs = auLongInputs if iOp1 == iLongOp1 and False else auShortInputs; 788 for iOp2 in range( len(oGen.oTarget.asGRegs)):794 for iOp2 in range(oGen.oTarget.getGRegCount(cAddrBits / 8)): 789 795 if iOp2 != 4 or cAddrBits == 16: 790 796 for uInput in auInputs: … … 798 804 # SIB. 799 805 self.generateStdTestGregMemSib(oGen, cAddrBits, cbEffOp, cbMaxOp, iOp1, auInputs); 806 break; 807 break; 808 800 809 801 810 return True; … … 1020 1029 aoffDisp = [ None, ]; 1021 1030 elif iMod == 1: 1022 aoffDisp = [ 127 & ~ cbAlignment, -128 ];1031 aoffDisp = [ 127 & ~(cbAlignment - 1), -128 ]; 1023 1032 elif iMod == 2: 1024 1033 aoffDisp = [ 2147483647 & ~(cbAlignment - 1), -2147483648 ]; … … 1139 1148 # Unpack it. 1140 1149 asParams = sName.split('_'); 1141 cAddrBits = int(asParams[0][:-3]); 1142 cEffOpBits = int(asParams[1][1:]); 1150 cAddrBits = int(asParams[0][:-3]); assert asParams[0][-3:] == 'bit'; 1151 cEffOpBits = int(asParams[1][1:]); assert asParams[1][0] == 'U'; 1143 1152 if cAddrBits == 64: asAddrGRegs = g_asGRegs64; 1144 1153 elif cAddrBits == 32: asAddrGRegs = g_asGRegs32; … … 1146 1155 1147 1156 i = 2; 1148 if i < len(asParams[i]) and asParams[i]: 1157 iBaseReg = None; 1158 sBaseReg = None; 1159 if i < len(asParams) and asParams[i] in asAddrGRegs: 1149 1160 sBaseReg = asParams[i]; 1161 iBaseReg = asAddrGRegs.index(sBaseReg); 1150 1162 i += 1 1151 try: 1152 iBaseReg = asAddrGRegs.index(sBaseReg); 1153 except ValueError: 1154 assert False, 'sBaseReg=%s' % (sBaseReg,); 1155 raise; 1163 1164 assert i < len(asParams); assert asParams[i][0] == 'x'; 1165 iScale = iScale = int(asParams[i][1:]); assert iScale in [1, 2, 4, 8]; 1166 i += 1; 1167 1168 sIndexReg = None; 1169 iIndexReg = None; 1170 if i < len(asParams) and asParams[i] in asAddrGRegs: 1171 sIndexReg = asParams[i]; 1172 iIndexReg = asAddrGRegs.index(sIndexReg); 1173 i += 1; 1156 1174 1157 1175 u32Disp = None; … … 1160 1178 i += 1; 1161 1179 1162 sIndexReg = None;1163 iIndexReg = None;1164 if i < len(asParams):1165 sIndexReg = asParams[i];1166 iBaseReg = asAddrGRegs.index(sBaseReg);1167 i += 1;1168 1169 iScale = 1;1170 if i < len(asParams):1171 iScale = int(asParams[i]); assert iScale in [2, 4, 8];1172 i += 1;1173 1174 1180 assert i == len(asParams), 'i=%d len=%d len[i]=%d (%s)' % (i, len(asParams), len(asParams[i]), asParams[i],); 1181 assert iScale == 1 or iIndexReg is not None; 1182 1183 # Find a temporary register. 1184 iTmpReg1 = X86_GREG_xCX; 1185 while iTmpReg1 in [iBaseReg, iIndexReg]: 1186 iTmpReg1 += 1; 1175 1187 1176 1188 # Prologue. 1177 iTmpReg1 = 0 if iBaseReg != 0 else 1;1178 1189 self.write('\n\n' 1190 '; cAddrBits=%s cEffOpBits=%s iBaseReg=%s u32Disp=%s iIndexReg=%s iScale=%s\n' 1179 1191 'VBINSTST_BEGINPROC Common_MemSetup_%s\n' 1180 1192 ' MY_PUSH_FLAGS\n' 1181 1193 ' push %s\n' 1182 % (sName, self.oTarget.asGRegs[iTmpReg1], )); 1183 self.write('; cAddrBits=%s cEffOpBits=%s iBaseReg=%s u32Disp=%s iIndexReg=%s iScale=%s\n' 1184 % (cAddrBits, cEffOpBits, iBaseReg, u32Disp, iIndexReg, iScale,)); 1194 % ( cAddrBits, cEffOpBits, iBaseReg, u32Disp, iIndexReg, iScale, 1195 sName, self.oTarget.asGRegs[iTmpReg1], )); 1185 1196 1186 1197 # Figure out what to use. … … 1195 1206 sDataVar = 'VBINSTST_NAME(g_u16Data)'; 1196 1207 else: 1197 assert cEffOpBits == 8; 1208 assert cEffOpBits == 8; assert iTmpReg1 < 4; 1198 1209 sTmpReg1 = g_asGRegs8Rex[iTmpReg1]; 1199 1210 sDataVar = 'VBINSTST_NAME(g_u8Data)'; 1200 1211 1201 # Load the value and mem address, sorting the value there. 1202 self.write(' mov %s, [xSP + sCB + MY_PUSH_FLAGS_SIZE + xCB]\n' % (sTmpReg1,)); 1203 if cAddrBits >= cDefAddrBits: 1204 self.write(' mov [%s xWrtRIP], %s\n' % (sDataVar, sTmpReg1,)); 1205 self.write(' lea %s, [%s xWrtRIP]\n' % (sBaseReg, sDataVar,)); 1212 # Special case: reg + reg * [2,4,8] 1213 if iBaseReg == iIndexReg and iBaseReg is not None and iScale != 1: 1214 iTmpReg2 = X86_GREG_xBP; 1215 while iTmpReg2 in [iBaseReg, iIndexReg, iTmpReg1]: 1216 iTmpReg2 += 1; 1217 sTmpReg2 = gregName(iTmpReg2, cAddrBits); 1218 self.write(' push sAX\n' 1219 ' push %s\n' 1220 ' push sDX\n' 1221 % (self.oTarget.asGRegs[iTmpReg2],)); 1222 if cAddrBits == 16: 1223 self.write(' mov %s, [VBINSTST_NAME(g_pvLow16Mem4K) xWrtRIP]\n' % (sTmpReg2,)); 1224 else: 1225 self.write(' mov %s, [VBINSTST_NAME(g_pvLow32Mem4K) xWrtRIP]\n' % (sTmpReg2,)); 1226 self.write(' add %s, 0x200\n' % (sTmpReg2,)); 1227 self.write(' mov %s, %s\n' % (gregName(X86_GREG_xAX, cAddrBits), sTmpReg2,)); 1228 if u32Disp is not None: 1229 self.write(' sub %s, %d\n' % ( gregName(X86_GREG_xAX, cAddrBits), convU32ToSigned(u32Disp), )); 1230 self.write(' xor edx, edx\n' 1231 '%if xCB == 2\n' 1232 ' push 0\n' 1233 '%endif\n'); 1234 self.write(' push %u\n' % (iScale + 1,)); 1235 self.write(' div %s [xSP]\n' % ('qword' if cAddrBits == 64 else 'dword',)); 1236 self.write(' sub %s, %s\n' % (sTmpReg2, gregName(X86_GREG_xDX, cAddrBits),)); 1237 self.write(' pop sDX\n' 1238 ' pop sDX\n'); # sTmpReg2 is eff address; sAX is sIndexReg value. 1239 # Note! sTmpReg1 can be xDX and that's no problem now. 1240 self.write(' mov %s, [xSP + sCB*3 + MY_PUSH_FLAGS_SIZE + xCB]\n' % (sTmpReg1,)); 1241 self.write(' mov [%s], %s\n' % (sTmpReg2, sTmpReg1,)); # Value in place. 1242 self.write(' pop %s\n' % (self.oTarget.asGRegs[iTmpReg2],)); 1243 if iBaseReg == X86_GREG_xAX: 1244 self.write(' pop %s\n' % (self.oTarget.asGRegs[iTmpReg1],)); 1245 else: 1246 self.write(' mov %s, %s\n' % (sBaseReg, gregName(X86_GREG_xAX, cAddrBits),)); 1247 self.write(' pop sAX\n'); 1248 1206 1249 else: 1207 1208 if cAddrBits == 16: 1209 self.write(' mov %s, [VBINSTST_NAME(g_pvLow16Mem4K) xWrtRIP]\n' % (sBaseReg,)); 1250 # Load the value and mem address, storing the value there. 1251 # Note! ASSUMES that the scale and disposition works fine together. 1252 sAddrReg = sBaseReg if sBaseReg is not None else sIndexReg; 1253 self.write(' mov %s, [xSP + sCB + MY_PUSH_FLAGS_SIZE + xCB]\n' % (sTmpReg1,)); 1254 if cAddrBits >= cDefAddrBits: 1255 self.write(' mov [%s xWrtRIP], %s\n' % (sDataVar, sTmpReg1,)); 1256 self.write(' lea %s, [%s xWrtRIP]\n' % (sAddrReg, sDataVar,)); 1210 1257 else: 1211 self.write(' mov %s, [VBINSTST_NAME(g_pvLow32Mem4K) xWrtRIP]\n' % (sBaseReg,)); 1212 self.write(' add %s, %s\n' % (sBaseReg, (randU16() << cEffOpBits) & 0xfff, )); 1213 self.write(' mov [%s], %s\n' % (sBaseReg, sTmpReg1, )); 1214 1215 # Adjust for disposition and scaling. 1216 if u32Disp is not None: 1217 self.write(' sub %s, %d\n' % ( sBaseReg, convU32ToSigned(u32Disp), )); 1218 if iIndexReg is not None: 1219 uIdxRegVal = randUxx(cAddrBits); 1220 self.write(' mov %s, %u\n' % ( sIndexReg, uIdxRegVal,)); 1221 if cAddrBits == 64: 1222 self.write(' sub %s, %#06x\n' % ( sBaseReg, uIdxRegVal * iScale, )); 1223 elif cAddrBits == 16: 1224 self.write(' sub %s, %#06x\n' % ( sBaseReg, (uIdxRegVal * iScale) & UINT32_MAX, )); 1225 else: 1226 assert cAddrBits == 16; 1227 self.write(' sub %s, %#06x\n' % ( sBaseReg, (uIdxRegVal * iScale) & UINT16_MAX, )); 1258 if cAddrBits == 16: 1259 self.write(' mov %s, [VBINSTST_NAME(g_pvLow16Mem4K) xWrtRIP]\n' % (sAddrReg,)); 1260 else: 1261 self.write(' mov %s, [VBINSTST_NAME(g_pvLow32Mem4K) xWrtRIP]\n' % (sAddrReg,)); 1262 self.write(' add %s, %s\n' % (sAddrReg, (randU16() << cEffOpBits) & 0xfff, )); 1263 self.write(' mov [%s], %s\n' % (sAddrReg, sTmpReg1, )); 1264 1265 # Adjust for disposition and scaling. 1266 if u32Disp is not None: 1267 self.write(' sub %s, %d\n' % ( sAddrReg, convU32ToSigned(u32Disp), )); 1268 if iIndexReg is not None: 1269 if iBaseReg == iIndexReg: 1270 assert iScale == 1; 1271 assert u32Disp is None or (u32Disp & 1) == 0; 1272 self.write(' shr %s, 1\n' % (sIndexReg,)); 1273 elif sBaseReg is not None: 1274 uIdxRegVal = randUxx(cAddrBits); 1275 if cAddrBits == 64: 1276 self.write(' mov %s, %u\n' 1277 ' sub %s, %s\n' 1278 ' mov %s, %u\n' 1279 % ( sIndexReg, (uIdxRegVal * iScale) & UINT64_MAX, 1280 sBaseReg, sIndexReg, 1281 sIndexReg, uIdxRegVal, )); 1282 else: 1283 assert cAddrBits == 32; 1284 self.write(' mov %s, %u\n' 1285 ' sub %s, %#06x\n' 1286 % ( sIndexReg, uIdxRegVal, sBaseReg, (uIdxRegVal * iScale) & UINT32_MAX, )); 1287 elif iScale == 2: 1288 assert u32Disp is None or (u32Disp & 1) == 0; 1289 self.write(' shr %s, 1\n' % (sIndexReg,)); 1290 elif iScale == 4: 1291 assert u32Disp is None or (u32Disp & 3) == 0; 1292 self.write(' shr %s, 2\n' % (sIndexReg,)); 1293 elif iScale == 8: 1294 assert u32Disp is None or (u32Disp & 7) == 0; 1295 self.write(' shr %s, 3\n' % (sIndexReg,)); 1296 else: 1297 assert iScale == 1; 1228 1298 1229 1299 # Set upper bits that's supposed to be unused. … … 1231 1301 if cDefAddrBits == 64: 1232 1302 assert cAddrBits == 32; 1233 self.write(' mov %s, %#018x\n' 1234 ' or %s, %s\n' 1235 % ( g_asGRegs64[iTmpReg1], randU64() & 0xffffffff00000000, 1236 g_asGRegs64[iBaseReg], g_asGRegs64[iTmpReg1],)); 1237 if iIndexReg is not None: 1303 if iBaseReg is not None: 1304 self.write(' mov %s, %#018x\n' 1305 ' or %s, %s\n' 1306 % ( g_asGRegs64[iTmpReg1], randU64() & 0xffffffff00000000, 1307 g_asGRegs64[iBaseReg], g_asGRegs64[iTmpReg1],)); 1308 if iIndexReg is not None and iIndexReg != iBaseReg: 1238 1309 self.write(' mov %s, %#018x\n' 1239 1310 ' or %s, %s\n' … … 1241 1312 g_asGRegs64[iIndexReg], g_asGRegs64[iTmpReg1],)); 1242 1313 else: 1243 assert cDefAddrBits == 32; assert cAddrBits == 16; 1244 self.write(' or %s, %#010x\n' 1245 % ( g_asGRegs32[iBaseReg], randU32() & 0xffff0000, )); 1246 if iIndexReg is not None: 1314 assert cDefAddrBits == 32; assert cAddrBits == 16; assert iIndexReg is None; 1315 if iBaseReg is not None: 1247 1316 self.write(' or %s, %#010x\n' 1248 % ( g_asGRegs32[i IndexReg], randU32() & 0xffff0000, ));1317 % ( g_asGRegs32[iBaseReg], randU32() & 0xffff0000, )); 1249 1318 1250 1319 # Epilogue. … … 1276 1345 1277 1346 # Register checks. 1278 iRegPrev = -1;1279 1347 for i in range(len(asRegs)): 1280 1348 sReg = asRegs[i]; … … 1333 1401 self.oFile = sys.stdout; 1334 1402 if self.oOptions.sOutputBase != '-': 1335 self.oFile = io.open(self.sFile, 'w', encoding = 'utf-8');1403 self.oFile = io.open(self.sFile, 'w', buffering = 65536, encoding = 'utf-8'); 1336 1404 1337 1405 self._generateFileHeader(); -
trunk/src/VBox/VMM/testcase/Instructions/env-common.mac
r46856 r46875 163 163 ; 164 164 ; Global data variables used by Common_SetupMemReadUxx. 165 ; For address calculation reasons, these must be qword aligned. 165 166 ; 166 167 BEGINDATA 168 dd 09d8af498h, 09ab3e5f8h 167 169 VBINSTST_GLOBALNAME_EX g_u64Data, data hidden 168 170 dq 0 171 dd 07d7af797h, 096b36562h 169 172 VBINSTST_GLOBALNAME_EX g_u32Data, data hidden 170 173 dd 0 174 dd 012305987h 171 175 VBINSTST_GLOBALNAME_EX g_u16Data, data hidden 172 176 dw 0 177 dw 05865h 178 dw 03863h 179 dw 02679h 173 180 VBINSTST_GLOBALNAME_EX g_u8Data, data hidden 174 181 db 0 175 182 db 90h 183 dw 0865ah 184 dd 058daffe2h 176 185 177 186 BEGINCODE
Note:
See TracChangeset
for help on using the changeset viewer.