VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-mode-TestDoModesByOne.c@ 74946

Last change on this file since 74946 was 69111, checked in by vboxsync, 7 years ago

(C) year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 14.5 KB
Line 
1/* $Id: bs3-mode-TestDoModesByOne.c 69111 2017-10-17 14:26:02Z vboxsync $ */
2/** @file
3 * BS3Kit - Bs3TestDoModesByOne
4 */
5
6/*
7 * Copyright (C) 2007-2017 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27
28/*********************************************************************************************************************************
29* Header Files *
30*********************************************************************************************************************************/
31#if TMPL_MODE == BS3_MODE_RM
32# define BS3_USE_RM_TEXT_SEG 1 /* Real mode version in RMTEXT16 segment to save space. */
33# include "bs3kit-template-header.h"
34# include "bs3-cmn-test.h"
35#else
36# include "bs3kit-template-header.h"
37# include "bs3-cmn-test.h"
38#endif
39#include "bs3-mode-TestDoModes.h"
40
41
42/*********************************************************************************************************************************
43* Assembly Symbols *
44*********************************************************************************************************************************/
45/* Assembly helpers for switching to the work bitcount and calling it. */
46BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo16_f16(uint8_t bMode);
47BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo16_c32(uint8_t bMode);
48BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo16_c64(uint8_t bMode);
49BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo32_f16(uint8_t bMode);
50BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo32_c32(uint8_t bMode);
51BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo32_c64(uint8_t bMode);
52BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo64_f16(uint8_t bMode);
53BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo64_c32(uint8_t bMode);
54BS3_DECL_FAR(uint8_t) Bs3TestCallDoerTo64_c64(uint8_t bMode);
55
56
57/** The current worker function, picked up by our assembly helpers. */
58#ifndef DOXYGEN_RUNNING
59# define g_pfnBs3TestDoModesByOneCurrent BS3_CMN_NM(g_pfnBs3TestDoModesByOneCurrent)
60#endif
61extern PFNBS3TESTDOMODE g_pfnBs3TestDoModesByOneCurrent;
62
63#include <iprt/asm-amd64-x86.h>
64
65
66#undef Bs3TestDoModesByOne
67BS3_MODE_DEF(void, Bs3TestDoModesByOne,(PCBS3TESTMODEBYONEENTRY paEntries, size_t cEntries, uint32_t fFlags))
68{
69 bool const fVerbose = true;
70 bool const fDoV86Modes = true;
71 bool const fDoWeirdV86Modes = true;
72 uint16_t const uCpuDetected = g_uBs3CpuDetected;
73 uint8_t const bCpuType = uCpuDetected & BS3CPU_TYPE_MASK;
74 bool const fHavePae = RT_BOOL(uCpuDetected & BS3CPU_F_PAE);
75 bool const fHaveLongMode = RT_BOOL(uCpuDetected & BS3CPU_F_LONG_MODE);
76 unsigned i;
77
78#if 1 /* debug. */
79 Bs3Printf("Bs3TestDoModesByOne: uCpuDetected=%#x fHavePae=%d fHaveLongMode=%d\n", uCpuDetected, fHavePae, fHaveLongMode);
80#endif
81
82 /*
83 * Inform about modes we won't test (if any).
84 */
85 if (bCpuType < BS3CPU_80286)
86 Bs3Printf("Only executing real-mode tests as no 80286+ CPU was detected.\n");
87 else if (bCpuType < BS3CPU_80386)
88 Bs3Printf("80286 CPU: Only executing 16-bit protected and real mode tests.\n");
89 else if (!fHavePae)
90 Bs3Printf("PAE and long mode tests will be skipped.\n");
91 else if (!fHaveLongMode)
92 Bs3Printf("Long mode tests will be skipped.\n");
93#if ARCH_BITS != 16
94 Bs3Printf("Real-mode tests will be skipped.\n");
95#endif
96
97 /*
98 * The real run.
99 */
100 for (i = 0; i < cEntries; i++)
101 {
102 const char *pszFmtStr = "Error #%u (%#x) in %s!\n";
103 bool fSkipped = true;
104 bool const fOnlyPaging = RT_BOOL(paEntries[i].fFlags & BS3TESTMODEBYONEENTRY_F_ONLY_PAGING);
105 uint8_t bErrNo;
106 Bs3TestSub(paEntries[i].pszSubTest);
107
108#define PRE_DO_CALL(a_szModeName) do { if (fVerbose) Bs3TestPrintf("...%s\n", a_szModeName); } while (0)
109#define CHECK_RESULT(a_szModeName) \
110 do { \
111 if (bErrNo != BS3TESTDOMODE_SKIPPED) \
112 { \
113 /*Bs3Printf("bErrNo=%#x %s\n", bErrNo, a_szModeName);*/ \
114 fSkipped = false; \
115 if (bErrNo != 0) \
116 Bs3TestFailedF(pszFmtStr, bErrNo, bErrNo, a_szModeName); \
117 } \
118 } while (0)
119
120 g_pfnBs3TestDoModesByOneCurrent = paEntries[i].pfnWorker;
121
122#if ARCH_BITS != 64
123
124# if ARCH_BITS == 16
125 if (!fOnlyPaging)
126 {
127 PRE_DO_CALL(g_szBs3ModeName_rm);
128 bErrNo = TMPL_NM(Bs3TestCallDoerInRM)(CONV_TO_RM_FAR16(paEntries[i].pfnWorker));
129 CHECK_RESULT(g_szBs3ModeName_rm);
130 }
131# endif
132
133 if (bCpuType < BS3CPU_80286)
134 {
135 if (fSkipped)
136 Bs3TestSkipped(NULL);
137 continue;
138 }
139
140 /*
141 * Unpaged prot mode.
142 */
143 if (!fOnlyPaging)
144 {
145 PRE_DO_CALL(g_szBs3ModeName_pe16);
146# if ARCH_BITS == 16
147 bErrNo = TMPL_NM(Bs3TestCallDoerInPE16)(CONV_TO_PROT_FAR16(paEntries[i].pfnWorker));
148# else
149 bErrNo = TMPL_NM(Bs3TestCallDoerInPE16)(CONV_TO_PROT_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
150# endif
151 CHECK_RESULT(g_szBs3ModeName_pe16);
152 }
153 if (bCpuType < BS3CPU_80386)
154 {
155 if (fSkipped)
156 Bs3TestSkipped(NULL);
157 continue;
158 }
159
160 if (!fOnlyPaging)
161 {
162 PRE_DO_CALL(g_szBs3ModeName_pe16_32);
163# if ARCH_BITS == 32
164 bErrNo = TMPL_NM(Bs3TestCallDoerInPE16_32)(CONV_TO_FLAT(paEntries[i].pfnWorker), BS3_MODE_PE16_32);
165# else
166 bErrNo = TMPL_NM(Bs3TestCallDoerInPE16_32)(CONV_TO_FLAT(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_c32)), BS3_MODE_PE16_32);
167# endif
168 CHECK_RESULT(g_szBs3ModeName_pe16_32);
169 }
170
171 if (fDoWeirdV86Modes && !fOnlyPaging)
172 {
173 PRE_DO_CALL(g_szBs3ModeName_pe16_v86);
174# if ARCH_BITS == 16
175 bErrNo = TMPL_NM(Bs3TestCallDoerInPE16_V86)(CONV_TO_RM_FAR16(paEntries[i].pfnWorker));
176# else
177 bErrNo = TMPL_NM(Bs3TestCallDoerInPE16_V86)(CONV_TO_RM_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
178# endif
179 CHECK_RESULT(g_szBs3ModeName_pe16_v86);
180 }
181
182 if (!fOnlyPaging)
183 {
184 PRE_DO_CALL(g_szBs3ModeName_pe32);
185# if ARCH_BITS == 32
186 bErrNo = TMPL_NM(Bs3TestCallDoerInPE32)(CONV_TO_FLAT(paEntries[i].pfnWorker), BS3_MODE_PE32);
187# else
188 bErrNo = TMPL_NM(Bs3TestCallDoerInPE32)(CONV_TO_FLAT(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_c32)), BS3_MODE_PE32);
189# endif
190 CHECK_RESULT(g_szBs3ModeName_pe32);
191 }
192
193 if (!fOnlyPaging)
194 {
195 PRE_DO_CALL(g_szBs3ModeName_pe32_16);
196# if ARCH_BITS == 16
197 bErrNo = TMPL_NM(Bs3TestCallDoerInPE32_16)(CONV_TO_PROT_FAR16(paEntries[i].pfnWorker));
198# else
199 bErrNo = TMPL_NM(Bs3TestCallDoerInPE32_16)(CONV_TO_PROT_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
200# endif
201 CHECK_RESULT(g_szBs3ModeName_pe32_16);
202 }
203
204 if (fDoV86Modes && !fOnlyPaging)
205 {
206 PRE_DO_CALL(g_szBs3ModeName_pev86);
207# if ARCH_BITS == 16
208 bErrNo = TMPL_NM(Bs3TestCallDoerInPEV86)(CONV_TO_RM_FAR16(paEntries[i].pfnWorker));
209# else
210 bErrNo = TMPL_NM(Bs3TestCallDoerInPEV86)(CONV_TO_RM_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
211# endif
212 CHECK_RESULT(g_szBs3ModeName_pev86);
213 }
214
215 /*
216 * Paged protected mode.
217 */
218 if (true)
219 {
220 PRE_DO_CALL(g_szBs3ModeName_pp16);
221# if ARCH_BITS == 16
222 bErrNo = TMPL_NM(Bs3TestCallDoerInPP16)(CONV_TO_PROT_FAR16(paEntries[i].pfnWorker));
223# else
224 bErrNo = TMPL_NM(Bs3TestCallDoerInPP16)(CONV_TO_PROT_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
225# endif
226 CHECK_RESULT(g_szBs3ModeName_pp16);
227 }
228
229 if (true)
230 {
231 PRE_DO_CALL(g_szBs3ModeName_pp16_32);
232# if ARCH_BITS == 32
233 bErrNo = TMPL_NM(Bs3TestCallDoerInPP16_32)(CONV_TO_FLAT(paEntries[i].pfnWorker), BS3_MODE_PP16_32);
234# else
235 bErrNo = TMPL_NM(Bs3TestCallDoerInPP16_32)(CONV_TO_FLAT(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_c32)), BS3_MODE_PP16_32);
236# endif
237 CHECK_RESULT(g_szBs3ModeName_pp16_32);
238 }
239
240 if (fDoWeirdV86Modes)
241 {
242 PRE_DO_CALL(g_szBs3ModeName_pp16_v86);
243# if ARCH_BITS == 16
244 bErrNo = TMPL_NM(Bs3TestCallDoerInPP16_V86)(CONV_TO_RM_FAR16(paEntries[i].pfnWorker));
245# else
246 bErrNo = TMPL_NM(Bs3TestCallDoerInPP16_V86)(CONV_TO_RM_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
247# endif
248 CHECK_RESULT(g_szBs3ModeName_pp16_v86);
249 }
250
251 if (true)
252 {
253 PRE_DO_CALL(g_szBs3ModeName_pp32);
254# if ARCH_BITS == 32
255 bErrNo = TMPL_NM(Bs3TestCallDoerInPP32)(CONV_TO_FLAT(paEntries[i].pfnWorker), BS3_MODE_PP32);
256# else
257 bErrNo = TMPL_NM(Bs3TestCallDoerInPP32)(CONV_TO_FLAT(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_c32)), BS3_MODE_PP32);
258# endif
259 CHECK_RESULT(g_szBs3ModeName_pp32);
260 }
261
262 if (true)
263 {
264 PRE_DO_CALL(g_szBs3ModeName_pp32_16);
265# if ARCH_BITS == 16
266 bErrNo = TMPL_NM(Bs3TestCallDoerInPP32_16)(CONV_TO_PROT_FAR16(paEntries[i].pfnWorker));
267# else
268 bErrNo = TMPL_NM(Bs3TestCallDoerInPP32_16)(CONV_TO_PROT_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
269# endif
270 CHECK_RESULT(g_szBs3ModeName_pp32_16);
271 }
272
273 if (fDoV86Modes)
274 {
275 PRE_DO_CALL(g_szBs3ModeName_ppv86);
276# if ARCH_BITS == 16
277 bErrNo = TMPL_NM(Bs3TestCallDoerInPPV86)(CONV_TO_RM_FAR16(paEntries[i].pfnWorker));
278# else
279 bErrNo = TMPL_NM(Bs3TestCallDoerInPPV86)(CONV_TO_RM_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
280# endif
281 CHECK_RESULT(g_szBs3ModeName_ppv86);
282 }
283
284
285 /*
286 * Protected mode with PAE paging.
287 */
288 if (true)
289 {
290 PRE_DO_CALL(g_szBs3ModeName_pae16);
291# if ARCH_BITS == 16
292 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE16)(CONV_TO_PROT_FAR16(paEntries[i].pfnWorker));
293# else
294 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE16)(CONV_TO_PROT_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
295# endif
296 CHECK_RESULT(g_szBs3ModeName_pae16);
297 }
298
299 if (true)
300 {
301 PRE_DO_CALL(g_szBs3ModeName_pae16_32);
302# if ARCH_BITS == 32
303 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE16_32)(CONV_TO_FLAT(paEntries[i].pfnWorker), BS3_MODE_PAE16_32);
304# else
305 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE16_32)(CONV_TO_FLAT(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_c32)), BS3_MODE_PAE16_32);
306# endif
307 CHECK_RESULT(g_szBs3ModeName_pae16_32);
308 }
309
310 if (fDoWeirdV86Modes)
311 {
312 PRE_DO_CALL(g_szBs3ModeName_pae16_v86);
313# if ARCH_BITS == 16
314 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE16_V86)(CONV_TO_RM_FAR16(paEntries[i].pfnWorker));
315# else
316 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE16_V86)(CONV_TO_RM_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
317# endif
318 CHECK_RESULT(g_szBs3ModeName_pae16_v86);
319 }
320
321 if (true)
322 {
323 PRE_DO_CALL(g_szBs3ModeName_pae32);
324# if ARCH_BITS == 32
325 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE32)(CONV_TO_FLAT(paEntries[i].pfnWorker), BS3_MODE_PAE32);
326# else
327 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE32)(CONV_TO_FLAT(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_c32)), BS3_MODE_PAE32);
328# endif
329 CHECK_RESULT(g_szBs3ModeName_pae32);
330 }
331
332 if (true)
333 {
334 PRE_DO_CALL(g_szBs3ModeName_pae32_16);
335# if ARCH_BITS == 16
336 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE32_16)(CONV_TO_PROT_FAR16(paEntries[i].pfnWorker));
337# else
338 bErrNo = TMPL_NM(Bs3TestCallDoerInPAE32_16)(CONV_TO_PROT_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
339# endif
340 CHECK_RESULT(g_szBs3ModeName_pae32_16);
341 }
342
343 if (fDoV86Modes)
344 {
345 PRE_DO_CALL(g_szBs3ModeName_paev86);
346# if ARCH_BITS == 16
347 bErrNo = TMPL_NM(Bs3TestCallDoerInPAEV86)(CONV_TO_RM_FAR16(paEntries[i].pfnWorker));
348# else
349 bErrNo = TMPL_NM(Bs3TestCallDoerInPAEV86)(CONV_TO_RM_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
350# endif
351 CHECK_RESULT(g_szBs3ModeName_paev86);
352 }
353
354#endif /* ARCH_BITS != 64 */
355
356 /*
357 * Long mode.
358 */
359 if (!fHaveLongMode)
360 {
361 if (fSkipped)
362 Bs3TestSkipped(NULL);
363 continue;
364 }
365
366 if (true)
367 {
368 PRE_DO_CALL(g_szBs3ModeName_lm16);
369#if ARCH_BITS == 16
370 bErrNo = TMPL_NM(Bs3TestCallDoerInLM16)(CONV_TO_PROT_FAR16(paEntries[i].pfnWorker));
371#else
372 bErrNo = TMPL_NM(Bs3TestCallDoerInLM16)(CONV_TO_PROT_FAR16(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_f16)));
373#endif
374 CHECK_RESULT(g_szBs3ModeName_lm16);
375 }
376
377 if (true)
378 {
379 PRE_DO_CALL(g_szBs3ModeName_lm32);
380#if ARCH_BITS == 32
381 bErrNo = TMPL_NM(Bs3TestCallDoerInLM32)(CONV_TO_FLAT(paEntries[i].pfnWorker));
382#else
383 bErrNo = TMPL_NM(Bs3TestCallDoerInLM32)(CONV_TO_FLAT(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_c32)));
384#endif
385 CHECK_RESULT(g_szBs3ModeName_lm32);
386 }
387
388 if (true)
389 {
390 PRE_DO_CALL(g_szBs3ModeName_lm64);
391#if ARCH_BITS == 64
392 bErrNo = TMPL_NM(Bs3TestCallDoerInLM64)(CONV_TO_FLAT(paEntries[i].pfnWorker), BS3_MODE_LM64);
393#else
394 bErrNo = TMPL_NM(Bs3TestCallDoerInLM64)(CONV_TO_FLAT(RT_CONCAT3(Bs3TestCallDoerTo,ARCH_BITS,_c64)), BS3_MODE_LM64);
395#endif
396 CHECK_RESULT(g_szBs3ModeName_lm64);
397 }
398
399 if (fSkipped)
400 Bs3TestSkipped("skipped\n");
401 }
402 Bs3TestSubDone();
403}
404
Note: See TracBrowser for help on using the repository browser.

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