VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-cmn-test.h@ 74886

Last change on this file since 74886 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: 4.9 KB
Line 
1/* $Id: bs3-cmn-test.h 69111 2017-10-17 14:26:02Z vboxsync $ */
2/** @file
3 * BS3Kit - Bs3Test internal header.
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#ifndef ___bs3_cmn_test_h
28#define ___bs3_cmn_test_h
29
30#include "bs3kit.h"
31#include <VBox/VMMDevTesting.h>
32
33
34/** Indicates whether the VMMDev is operational. */
35#ifndef DOXYGEN_RUNNING
36# define g_fbBs3VMMDevTesting BS3_DATA_NM(g_fbBs3VMMDevTesting)
37#endif
38extern bool g_fbBs3VMMDevTesting;
39
40/** The number of tests that have failed. */
41#ifndef DOXYGEN_RUNNING
42# define g_cusBs3TestErrors BS3_DATA_NM(g_cusBs3TestErrors)
43#endif
44extern uint16_t g_cusBs3TestErrors;
45
46/** The start error count of the current subtest. */
47#ifndef DOXYGEN_RUNNING
48# define g_cusBs3SubTestAtErrors BS3_DATA_NM(g_cusBs3SubTestAtErrors)
49#endif
50extern uint16_t g_cusBs3SubTestAtErrors;
51
52/** Whether we've reported the sub-test result or not. */
53#ifndef DOXYGEN_RUNNING
54# define g_fbBs3SubTestReported BS3_DATA_NM(g_fbBs3SubTestReported)
55#endif
56extern bool g_fbBs3SubTestReported;
57/** Whether the sub-test has been skipped or not. */
58#ifndef DOXYGEN_RUNNING
59# define g_fbBs3SubTestSkipped BS3_DATA_NM(g_fbBs3SubTestSkipped)
60#endif
61extern bool g_fbBs3SubTestSkipped;
62
63/** The number of sub tests. */
64#ifndef DOXYGEN_RUNNING
65# define g_cusBs3SubTests BS3_DATA_NM(g_cusBs3SubTests)
66#endif
67extern uint16_t g_cusBs3SubTests;
68
69/** The number of sub tests that failed. */
70#ifndef DOXYGEN_RUNNING
71# define g_cusBs3SubTestsFailed BS3_DATA_NM(g_cusBs3SubTestsFailed)
72#endif
73extern uint16_t g_cusBs3SubTestsFailed;
74
75/** VMMDEV_TESTING_UNIT_XXX -> string */
76#ifndef DOXYGEN_RUNNING
77# define g_aszBs3TestUnitNames BS3_DATA_NM(g_aszBs3TestUnitNames)
78#endif
79extern char const g_aszBs3TestUnitNames[][16];
80
81/** The test name. */
82extern const char BS3_FAR *g_pszBs3Test_c16;
83extern const char *g_pszBs3Test_c32;
84extern const char *g_pszBs3Test_c64;
85
86/** The subtest name. */
87#ifndef DOXYGEN_RUNNING
88# define g_szBs3SubTest BS3_DATA_NM(g_szBs3SubTest)
89#endif
90extern char g_szBs3SubTest[64];
91
92
93/**
94 * Sends a command to VMMDev followed by a single string.
95 *
96 * If the VMMDev is not present or is not being used, this function will
97 * do nothing.
98 *
99 * @param uCmd The command.
100 * @param pszString The string.
101 */
102#ifndef DOXYGEN_RUNNING
103# define bs3TestSendCmdWithStr BS3_CMN_NM(bs3TestSendCmdWithStr)
104#endif
105BS3_DECL(void) bs3TestSendCmdWithStr(uint32_t uCmd, const char BS3_FAR *pszString);
106
107/**
108 * Sends a command to VMMDev followed by a 32-bit unsigned integer value.
109 *
110 * If the VMMDev is not present or is not being used, this function will
111 * do nothing.
112 *
113 * @param uCmd The command.
114 * @param uValue The value.
115 */
116#ifndef DOXYGEN_RUNNING
117# define bs3TestSendCmdWithU32 BS3_CMN_NM(bs3TestSendCmdWithU32)
118#endif
119BS3_DECL(void) bs3TestSendCmdWithU32(uint32_t uCmd, uint32_t uValue);
120
121/**
122 * Checks if the VMMDev is configured for testing.
123 *
124 * @returns true / false.
125 */
126#ifndef DOXYGEN_RUNNING
127# define bs3TestIsVmmDevTestingPresent BS3_CMN_NM(bs3TestIsVmmDevTestingPresent)
128#endif
129BS3_DECL(bool) bs3TestIsVmmDevTestingPresent(void);
130
131/**
132 * Similar to rtTestSubCleanup.
133 */
134#ifndef DOXYGEN_RUNNING
135# define bs3TestSubCleanup BS3_CMN_NM(bs3TestSubCleanup)
136#endif
137BS3_DECL(void) bs3TestSubCleanup(void);
138
139/**
140 * @callback_method_impl{FNBS3STRFORMATOUTPUT,
141 * Used by Bs3TestFailedV and Bs3TestSkippedV.
142 *
143 * The @a pvUser parameter must point a BS3TESTFAILEDBUF structure. }
144 */
145#ifndef DOXYGEN_RUNNING
146# define bs3TestFailedStrOutput BS3_CMN_NM(bs3TestFailedStrOutput)
147#endif
148BS3_DECL_CALLBACK(size_t) bs3TestFailedStrOutput(char ch, void BS3_FAR *pvUser);
149
150/**
151 * Output buffering for bs3TestFailedStrOutput.
152 */
153typedef struct BS3TESTFAILEDBUF
154{
155 /** Initialize to false. */
156 bool fNewLine;
157 /** Initialize to zero. */
158 uint8_t cchBuf;
159 /** Buffer, uninitialized. */
160 char achBuf[128];
161} BS3TESTFAILEDBUF;
162/** Pointer to a bs3TestFailedStrOutput buffer. */
163typedef BS3TESTFAILEDBUF BS3_FAR *PBS3TESTFAILEDBUF;
164
165#endif
166
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