VirtualBox

source: vbox/trunk/src/VBox/Runtime/testcase/tstRTTls-1.cpp@ 93465

Last change on this file since 93465 was 93115, checked in by vboxsync, 3 years ago

scm --update-copyright-year

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 4.1 KB
Line 
1/* $Id: tstRTTls-1.cpp 93115 2022-01-01 11:31:46Z vboxsync $ */
2/** @file
3 * IPRT Testcase - Thread Local Storage (TLS).
4 */
5
6/*
7 * Copyright (C) 2020-2022 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#include <iprt/thread.h>
32
33#include <iprt/asm.h>
34#include <iprt/errcore.h>
35#include <iprt/test.h>
36#include <iprt/time.h>
37
38
39/*********************************************************************************************************************************
40* Global Variables *
41*********************************************************************************************************************************/
42static RTTEST g_hTest;
43static uint32_t volatile g_cDtorCalls = 0;
44
45/**
46 * @callback_method_impl{FNRTTLSDTOR}
47 */
48static DECLCALLBACK(void) testDtorCallback(void *pvValue)
49{
50 RTTEST_CHECK(g_hTest, pvValue != NULL);
51 ASMAtomicIncU32(&g_cDtorCalls);
52}
53
54
55static DECLCALLBACK(int) testDtorThread1(RTTHREAD hSelf, void *pvUser)
56{
57 RTTEST_CHECK_RC(g_hTest, RTTlsSet((RTTLS)pvUser, hSelf), VINF_SUCCESS);
58 return VINF_SUCCESS;
59}
60
61
62static void testDtor(void)
63{
64 RTTestISub("TLS Destructors");
65
66 g_cDtorCalls = 0;
67 RTTLS iTls;
68 int rc = RTTlsAllocEx(&iTls, testDtorCallback);
69 if (rc == VERR_NOT_SUPPORTED)
70 {
71 RTTestSkipped(g_hTest, "RTTlsAllocEx -> VERR_NOT_SUPPORTED");
72 return;
73 }
74 RTTESTI_CHECK_RC_RETV(rc, VINF_SUCCESS);
75
76 RTTHREAD ahThreads[16];
77 uint32_t cThreads = 0;
78 while (cThreads < RT_ELEMENTS(ahThreads))
79 {
80 RTTESTI_CHECK_RC_BREAK(RTThreadCreateF(&ahThreads[cThreads], testDtorThread1, (void *)iTls, 0, RTTHREADTYPE_DEFAULT,
81 RTTHREADFLAGS_WAITABLE, "dtor-%u", cThreads), VINF_SUCCESS);
82 cThreads++;
83 }
84 uint32_t const cExpectedDtorCalls = cThreads;
85
86 while (cThreads-- > 0)
87 RTTESTI_CHECK_RC(RTThreadWait(ahThreads[cThreads], RT_MS_30SEC, NULL), VINF_SUCCESS);
88
89 /* RTThreadWait will return while the native portition of the thread may
90 still be shutting down, so we need to fudge a little here. */
91 uint64_t const nsStart = RTTimeNanoTS();
92 RTMSINTERVAL nsSleep = 2;
93 while ( ASMAtomicReadU32(&g_cDtorCalls) != cExpectedDtorCalls
94 && RTTimeNanoTS() - nsStart < RT_NS_10SEC)
95 {
96 nsSleep = RT_MAX(nsSleep + 1, 128);
97 RTThreadSleep(nsSleep);
98 }
99
100 uint32_t cCalls = ASMAtomicReadU32(&g_cDtorCalls);
101 if (cCalls != cExpectedDtorCalls)
102 RTTestFailed(g_hTest, "%u dtor calls, expected %u\n", cCalls, cExpectedDtorCalls);
103
104 RTTESTI_CHECK_RC(RTTlsFree(iTls), VINF_SUCCESS);
105}
106
107
108int main()
109{
110 RTEXITCODE rcExit = RTTestInitAndCreate("tstRTStrCatCopy", &g_hTest);
111 if (rcExit != RTEXITCODE_SUCCESS)
112 return rcExit;
113
114 testDtor();
115
116 return RTTestSummaryAndDestroy(g_hTest);
117}
118
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