VirtualBox

source: vbox/trunk/src/VBox/Runtime/testcase/tstR0ThreadPreemptionDriver.cpp@ 20554

Last change on this file since 20554 was 19970, checked in by vboxsync, 16 years ago

tstR0ThreadPreemption: Some adjustments.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.7 KB
Line 
1/* $Id: tstR0ThreadPreemptionDriver.cpp 19970 2009-05-24 16:22:00Z vboxsync $ */
2/** @file
3 * IPRT R0 Testcase - Thread Preemption, driver program.
4 */
5
6/*
7 * Copyright (C) 2009 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
27 * Clara, CA 95054 USA or visit http://www.sun.com if you need
28 * additional information or have any questions.
29 */
30
31/*******************************************************************************
32* Header Files *
33*******************************************************************************/
34#include <iprt/initterm.h>
35
36#include <iprt/err.h>
37#include <iprt/path.h>
38#include <iprt/param.h>
39#include <iprt/stream.h>
40#include <iprt/string.h>
41#include <iprt/test.h>
42#include <iprt/thread.h>
43#ifdef VBOX
44# include <VBox/sup.h>
45# include "tstR0ThreadPreemption.h"
46#endif
47
48
49int main(int argc, char **argv)
50{
51#ifndef VBOX
52 RTPrintf("tstSup: SKIPPED\n");
53 return 0;
54#else
55 /*
56 * Init.
57 */
58 int rc = RTR3InitAndSUPLib();
59 if (RT_FAILURE(rc))
60 {
61 RTPrintf("tstR0ThreadPreemption: fatal error: RTR3InitAndSUPLib failed with rc=%Rrc\n", rc);
62 return 1;
63 }
64
65 RTTEST hTest;
66 rc = RTTestCreate("tstR0ThreadPreemption", &hTest);
67 if (RT_FAILURE(rc))
68 {
69 RTPrintf("tstR0ThreadPreemption: fatal error: RTTestCreate failed with rc=%Rrc\n", rc);
70 return 1;
71 }
72 RTTestBanner(hTest);
73
74 PSUPDRVSESSION pSession;
75 rc = SUPR3Init(&pSession);
76 if (RT_FAILURE(rc))
77 {
78 RTTestFailed(hTest, "SUPR3Init failed with rc=%Rrc\n", rc);
79 return RTTestSummaryAndDestroy(hTest);
80 }
81
82 char szPath[RTPATH_MAX];
83 rc = RTPathExecDir(szPath, sizeof(szPath));
84 if (RT_SUCCESS(rc))
85 rc = RTPathAppend(szPath, sizeof(szPath), "tstR0ThreadPreemption.r0");
86 if (RT_FAILURE(rc))
87 {
88 RTTestFailed(hTest, "Failed constructing .r0 filename (rc=%Rrc)", rc);
89 return RTTestSummaryAndDestroy(hTest);
90 }
91
92 void *pvImageBase;
93 rc = SUPR3LoadServiceModule(szPath, "tstR0ThreadPreemption",
94 "TSTR0ThreadPreemptionSrvReqHandler",
95 &pvImageBase);
96 if (RT_FAILURE(rc))
97 {
98 RTTestFailed(hTest, "SUPR3LoadServiceModule(%s,,,) failed with rc=%Rrc\n", szPath, rc);
99 return RTTestSummaryAndDestroy(hTest);
100 }
101
102 /* test request */
103 struct
104 {
105 SUPR0SERVICEREQHDR Hdr;
106 char szMsg[256];
107 } Req;
108
109 /*
110 * Sanity checks.
111 */
112 RTTestSub(hTest, "Sanity");
113 Req.Hdr.u32Magic = SUPR0SERVICEREQHDR_MAGIC;
114 Req.Hdr.cbReq = sizeof(Req);
115 Req.szMsg[0] = '\0';
116 RTTESTI_CHECK_RC(rc = SUPR3CallR0Service("tstR0ThreadPreemption", sizeof("tstR0ThreadPreemption") - 1,
117 TSTR0THREADPREMEPTION_SANITY_OK, 0, &Req.Hdr), VINF_SUCCESS);
118 if (RT_FAILURE(rc))
119 return RTTestSummaryAndDestroy(hTest);
120 RTTESTI_CHECK_MSG(Req.szMsg[0] == '\0', ("%s", Req.szMsg));
121 if (Req.szMsg[0] != '\0')
122 return RTTestSummaryAndDestroy(hTest);
123
124 Req.Hdr.u32Magic = SUPR0SERVICEREQHDR_MAGIC;
125 Req.Hdr.cbReq = sizeof(Req);
126 Req.szMsg[0] = '\0';
127 RTTESTI_CHECK_RC(rc = SUPR3CallR0Service("tstR0ThreadPreemption", sizeof("tstR0ThreadPreemption") - 1,
128 TSTR0THREADPREMEPTION_SANITY_FAILURE, 0, &Req.Hdr), VINF_SUCCESS);
129 if (RT_FAILURE(rc))
130 return RTTestSummaryAndDestroy(hTest);
131 RTTESTI_CHECK_MSG(!strncmp(Req.szMsg, "!42failure42", sizeof("!42failure42") - 1), ("%s", Req.szMsg));
132 if (strncmp(Req.szMsg, "!42failure42", sizeof("!42failure42") - 1))
133 return RTTestSummaryAndDestroy(hTest);
134
135 /*
136 * Basic tests, bail out on failure.
137 */
138 RTTestSub(hTest, "Basics");
139 Req.Hdr.u32Magic = SUPR0SERVICEREQHDR_MAGIC;
140 Req.Hdr.cbReq = sizeof(Req);
141 Req.szMsg[0] = '\0';
142 RTTESTI_CHECK_RC(rc = SUPR3CallR0Service("tstR0ThreadPreemption", sizeof("tstR0ThreadPreemption") - 1,
143 TSTR0THREADPREMEPTION_BASIC, 0, &Req.Hdr), VINF_SUCCESS);
144 if (RT_FAILURE(rc))
145 return RTTestSummaryAndDestroy(hTest);
146 if (Req.szMsg[0] == '!')
147 {
148 RTTestIFailed("%s", &Req.szMsg[1]);
149 return RTTestSummaryAndDestroy(hTest);
150 }
151 if (Req.szMsg[0])
152 RTTestIPrintf(RTTESTLVL_ALWAYS, "%s", Req.szMsg);
153
154 /*
155 * Stay in ring-0 until preemption is pending.
156 */
157 RTTestSub(hTest, "Pending Preemption");
158 for (int i = 0; ; i++)
159 {
160 Req.Hdr.u32Magic = SUPR0SERVICEREQHDR_MAGIC;
161 Req.Hdr.cbReq = sizeof(Req);
162 Req.szMsg[0] = '\0';
163 RTTESTI_CHECK_RC(rc = SUPR3CallR0Service("tstR0ThreadPreemption", sizeof("tstR0ThreadPreemption") - 1,
164 TSTR0THREADPREMEPTION_IS_PENDING, 0, &Req.Hdr), VINF_SUCCESS);
165 if ( strcmp(Req.szMsg, "cLoops=1\n")
166 || i >= 64)
167 {
168 if (Req.szMsg[0] == '!')
169 RTTestIFailed("%s", &Req.szMsg[1]);
170 else if (Req.szMsg[0])
171 RTTestIPrintf(RTTESTLVL_ALWAYS, "%s", Req.szMsg);
172 break;
173 }
174 if ((i % 3) == 0)
175 RTThreadYield();
176 }
177
178 /*
179 * Test nested RTThreadPreemptDisable calls.
180 */
181 RTTestSub(hTest, "Nested");
182 Req.Hdr.u32Magic = SUPR0SERVICEREQHDR_MAGIC;
183 Req.Hdr.cbReq = sizeof(Req);
184 Req.szMsg[0] = '\0';
185 RTTESTI_CHECK_RC(rc = SUPR3CallR0Service("tstR0ThreadPreemption", sizeof("tstR0ThreadPreemption") - 1,
186 TSTR0THREADPREMEPTION_NESTED, 0, &Req.Hdr), VINF_SUCCESS);
187 if (Req.szMsg[0] == '!')
188 RTTestIFailed("%s", &Req.szMsg[1]);
189 else if (Req.szMsg[0])
190 RTTestIPrintf(RTTESTLVL_ALWAYS, "%s", Req.szMsg);
191
192 /*
193 * Done.
194 */
195 return RTTestSummaryAndDestroy(hTest);
196#endif
197}
198
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