kerneltest/e32test/system/t_condvar.cpp
author hgs
Mon, 26 Jul 2010 10:52:56 +0100
changeset 231 75252ea6123b
parent 132 e4a7b1cbe40c
child 293 0659d0e1a03c
permissions -rw-r--r--
201029_03
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
132
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     1
// Copyright (c) 1994-2009 Nokia Corporation and/or its subsidiary(-ies).
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     2
// All rights reserved.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     3
// This component and the accompanying materials are made available
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     4
// under the terms of the License "Eclipse Public License v1.0"
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     5
// which accompanies this distribution, and is available
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     7
//
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     8
// Initial Contributors:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
     9
// Nokia Corporation - initial contribution.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    10
//
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    11
// Contributors:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    12
//
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    13
// Description:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    14
// e32test\system\t_condvar.cpp
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    15
// Overview:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    16
// Test the use of the RCondVar & RMutex classes.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    17
// API Information:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    18
// RCondVar, RMutex
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    19
// Details:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    20
// - Create some local conditional variables and mutexes and verify results
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    21
// are as expected.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    22
// - Create a test thread that waits on conditional variables and mutexes, 
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    23
// append some items on an array, signal the conditional variable and mutex,
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    24
// the thread then counts the number of items on the array and passes the 
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    25
// result back to the main process. Verify results are as expected. Repeat
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    26
// with different array data.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    27
// - Verify that a RCondVar::Wait() panics when the thread does not hold the
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    28
// specified mutex (mutex not locked).
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    29
// - Test using two mutexes with 1 conditional variable, append some items to 
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    30
// an array, verify results from the thread are as expected. 
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    31
// - Create a second thread with higher priority, perform tests similar to
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    32
// above, verify results are as expected.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    33
// - Verify the thread timeout values are as expected.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    34
// - Create global conditional variables and global mutexes, using two threads
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    35
// test the RCondVar::Signal() and RMutex::Wait() results are as expected.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    36
// - Test various combinations of creating a thread, suspending and killing it
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    37
// and signalling a conditional variable and mutex. Verify results are as
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    38
// expected.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    39
// - Create a secondary process along with a global chunk, conditional variable 
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    40
// and mutex. Signal the conditional variable and verify the results are as 
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    41
// expected.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    42
// - Using two threads, benchmark the number of conditional variable/mutex Signal
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    43
// and Wait iterations that can be completed per second.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    44
// Platforms/Drives/Compatibility:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    45
// All.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    46
// Assumptions/Requirement/Pre-requisites:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    47
// Failures and causes:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    48
// Base Port information:
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    49
// 
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    50
//
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    51
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    52
#include <e32std.h>
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    53
#include <e32std_private.h>
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    54
#include <e32svr.h>
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    55
#include <e32test.h>
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    56
#include <e32ldr.h>
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    57
#include <e32def.h>
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    58
#include <e32def_private.h>
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    59
#include <u32std.h>
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    60
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    61
RTest test(_L("T_CONDVAR"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    62
RMutex M1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    63
RMutex M2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    64
RCondVar CV1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    65
RCondVar CV2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    66
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    67
#define __TRACE_LINE__	test.Printf(_L("Line %d\n"),__LINE__)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    68
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    69
struct SThreadData
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    70
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    71
	SThreadData();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    72
	RMutex iM;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    73
	RCondVar iV;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    74
	RArray<TInt>* iA;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    75
	TInt iTotal;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    76
	TInt iInnerLoops;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    77
	TInt iOuterLoops;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    78
	TInt iTimeoutMs;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    79
	TInt iTimeouts;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    80
	TInt iBadCount;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    81
	};
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    82
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    83
struct SThreadData2
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    84
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    85
	SThreadData2();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    86
	const TText* iMutexName;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    87
	const TText* iCondVarName;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    88
	TInt iInnerLoops;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    89
	};
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    90
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    91
SThreadData::SThreadData()
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    92
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    93
	memset(this, 0, sizeof(*this));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    94
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    95
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    96
SThreadData2::SThreadData2()
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    97
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    98
	memset(this, 0, sizeof(*this));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
    99
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   100
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   101
TInt Thread0(TAny*)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   102
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   103
	return CV1.Wait(M1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   104
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   105
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   106
TInt Thread1(TAny* a)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   107
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   108
	TUint32 t1, t2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   109
	SThreadData& d = *(SThreadData*)a;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   110
	TInt r = KErrNone;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   111
	TInt i = 0;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   112
	d.iM.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   113
	FOREVER
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   114
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   115
		while (d.iA->Count()<=i && r==KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   116
			{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   117
			t1 = User::NTickCount();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   118
			if (d.iTimeoutMs)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   119
				r = d.iV.TimedWait(d.iM, d.iTimeoutMs*1000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   120
			else
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   121
				r = d.iV.Wait(d.iM);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   122
			t2 = User::NTickCount();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   123
			++d.iInnerLoops;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   124
			if (r == KErrTimedOut)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   125
				{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   126
				++d.iTimeouts;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   127
				TInt iv = (TInt)(t2-t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   128
				if (iv<d.iTimeoutMs)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   129
					++d.iBadCount;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   130
				r = KErrNone;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   131
				}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   132
			}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   133
		if (r != KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   134
			break;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   135
		++d.iOuterLoops;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   136
		TInt c = d.iA->Count();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   137
		for (; i<c; ++i)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   138
			d.iTotal += (*d.iA)[i];
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   139
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   140
	return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   141
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   142
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   143
TInt Thread2(TAny* a)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   144
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   145
	TUint32 t1, t2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   146
	SThreadData& d = *(SThreadData*)a;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   147
	TInt r = KErrNone;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   148
	d.iM.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   149
	RThread::Rendezvous(KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   150
	while (r==KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   151
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   152
		t1 = User::NTickCount();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   153
		if (d.iTimeoutMs)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   154
			r = d.iV.TimedWait(d.iM, d.iTimeoutMs*1000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   155
		else
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   156
			r = d.iV.Wait(d.iM);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   157
		t2 = User::NTickCount();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   158
		++d.iInnerLoops;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   159
		if (r == KErrTimedOut)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   160
			{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   161
			++d.iTimeouts;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   162
			TInt iv = (TInt)(t2-t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   163
			if (iv<d.iTimeoutMs)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   164
				++d.iBadCount;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   165
			r = KErrNone;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   166
			}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   167
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   168
	return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   169
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   170
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   171
TInt Thread3(TAny* a)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   172
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   173
	SThreadData2& d = *(SThreadData2*)a;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   174
	RMutex m;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   175
	RCondVar cv;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   176
	TInt r = m.OpenGlobal(TPtrC(d.iMutexName), EOwnerThread);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   177
	if (r!=KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   178
		return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   179
	r = cv.OpenGlobal(TPtrC(d.iCondVarName), EOwnerThread);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   180
	if (r!=KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   181
		return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   182
	m.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   183
	while (r==KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   184
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   185
		r = cv.Wait(m);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   186
		++d.iInnerLoops;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   187
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   188
	return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   189
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   190
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   191
TInt Thread4(TAny* a)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   192
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   193
	volatile TInt& count = *(volatile TInt*)a;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   194
	TInt r = KErrNone;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   195
	M2.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   196
	while (r==KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   197
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   198
		r = CV2.Wait(M2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   199
		++count;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   200
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   201
	return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   202
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   203
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   204
TInt Thread5(TAny*)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   205
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   206
	FOREVER
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   207
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   208
		M2.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   209
		CV2.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   210
		M2.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   211
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   212
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   213
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   214
void RunBench()
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   215
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   216
	test.Next(_L("Benchmark"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   217
	RThread t4, t5;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   218
	TInt count = 0;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   219
	TInt r = t4.Create(KNullDesC, &Thread4, 0x1000, 0x1000, 0x1000, &count);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   220
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   221
	t4.SetPriority(EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   222
	r = t5.Create(KNullDesC, &Thread5, 0x1000, 0x1000, 0x1000, NULL);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   223
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   224
	t5.SetPriority(EPriorityMuchLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   225
	t4.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   226
	t5.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   227
	User::After(500000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   228
	TInt initc = count;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   229
	User::After(5000000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   230
	TInt finalc = count;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   231
	test.Printf(_L("%d iterations per second\n"), (finalc-initc)/5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   232
	t4.Kill(0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   233
	t5.Kill(0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   234
	CLOSE_AND_WAIT(t4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   235
	CLOSE_AND_WAIT(t5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   236
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   237
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   238
void CreateThread2(RThread& aThread, SThreadData& aData, TThreadPriority aPri)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   239
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   240
	TInt r = aThread.Create(KNullDesC, &Thread2, 0x1000, 0x1000, 0x1000, &aData);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   241
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   242
	aThread.SetPriority(aPri);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   243
	TRequestStatus s;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   244
	aThread.Rendezvous(s);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   245
	test(s==KRequestPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   246
	aThread.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   247
	User::WaitForRequest(s);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   248
	test(s==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   249
	test(aThread.ExitType()==EExitPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   250
	aData.iM.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   251
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   252
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   253
void KillThread2(RThread& aThread)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   254
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   255
	TRequestStatus s;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   256
	aThread.Logon(s);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   257
	test(s==KRequestPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   258
	aThread.Terminate(0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   259
	User::WaitForRequest(s);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   260
	test(aThread.ExitType()==EExitTerminate);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   261
	test(aThread.ExitReason()==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   262
	test(s==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   263
	CLOSE_AND_WAIT(aThread);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   264
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   265
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   266
void AppendToArray(SThreadData& aD, TInt aCount, ...)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   267
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   268
	VA_LIST list;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   269
	VA_START(list,aCount);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   270
	aD.iM.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   271
	while(--aCount>=0)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   272
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   273
		test(aD.iA->Append(VA_ARG(list,TInt))==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   274
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   275
	aD.iV.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   276
	aD.iM.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   277
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   278
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   279
void AppendToArrayB(SThreadData& aD, TInt aCount, ...)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   280
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   281
	VA_LIST list;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   282
	VA_START(list,aCount);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   283
	aD.iM.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   284
	while(--aCount>=0)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   285
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   286
		test(aD.iA->Append(VA_ARG(list,TInt))==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   287
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   288
	aD.iV.Broadcast();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   289
	aD.iM.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   290
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   291
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   292
void AppendToArrayB2(SThreadData& aD, TInt aCount, ...)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   293
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   294
	VA_LIST list;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   295
	VA_START(list,aCount);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   296
	aD.iM.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   297
	while(--aCount>=0)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   298
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   299
		test(aD.iA->Append(VA_ARG(list,TInt))==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   300
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   301
	aD.iM.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   302
	aD.iV.Broadcast();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   303
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   304
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   305
void Thread2Test()
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   306
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   307
	test.Next(_L("Thread2Test"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   308
	RCondVar cv2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   309
	RMutex m3;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   310
	TInt r = cv2.CreateLocal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   311
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   312
	r = m3.CreateLocal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   313
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   314
	SThreadData d1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   315
	d1.iM = m3;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   316
	d1.iV = cv2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   317
	RThread t1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   318
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   319
	CreateThread2(t1, d1, EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   320
	cv2.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   321
	m3.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   322
	User::After(100000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   323
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   324
	KillThread2(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   325
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   326
	CreateThread2(t1, d1, EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   327
	KillThread2(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   328
	m3.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   329
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   330
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   331
	CreateThread2(t1, d1, EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   332
	m3.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   333
	User::After(10000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   334
	KillThread2(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   335
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   336
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   337
	CreateThread2(t1, d1, EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   338
	cv2.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   339
	User::After(10000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   340
	KillThread2(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   341
	m3.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   342
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   343
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   344
	CreateThread2(t1, d1, EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   345
	t1.Suspend();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   346
	KillThread2(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   347
	m3.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   348
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   349
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   350
	CreateThread2(t1, d1, EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   351
	User::After(10000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   352
	t1.Suspend();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   353
	KillThread2(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   354
	m3.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   355
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   356
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   357
	CreateThread2(t1, d1, EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   358
	cv2.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   359
	t1.Suspend();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   360
	KillThread2(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   361
	m3.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   362
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   363
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   364
	CreateThread2(t1, d1, EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   365
	cv2.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   366
	User::After(10000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   367
	t1.Suspend();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   368
	KillThread2(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   369
	m3.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   370
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   371
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   372
	cv2.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   373
	m3.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   374
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   375
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   376
const TText* KMutex1Name = _S("mtx1");
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   377
const TText* KMutex2Name = _S("mtx2");
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   378
const TText* KCondVar1Name = _S("cv1");
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   379
const TText* KCondVar2Name = _S("cv2");
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   380
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   381
void TestGlobal()
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   382
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   383
	test.Next(_L("Test Global"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   384
	RMutex mg1, mg2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   385
	RCondVar cvg1, cvg2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   386
	TInt r = mg1.CreateGlobal(TPtrC(KMutex1Name));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   387
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   388
	r = mg2.CreateGlobal(TPtrC(KMutex2Name));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   389
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   390
	r = cvg1.CreateGlobal(TPtrC(KCondVar1Name));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   391
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   392
	r = cvg2.CreateGlobal(TPtrC(KCondVar2Name));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   393
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   394
	SThreadData2 d1, d2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   395
	d1.iMutexName = KMutex1Name;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   396
	d1.iCondVarName = KCondVar1Name;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   397
	d2.iMutexName = KMutex2Name;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   398
	d2.iCondVarName = KCondVar2Name;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   399
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   400
	RThread t1, t2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   401
	r = t1.Create(KNullDesC, &Thread3, 0x1000, 0x1000, 0x1000, &d1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   402
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   403
	t1.SetPriority(EPriorityMore);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   404
	TRequestStatus s1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   405
	t1.Logon(s1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   406
	t1.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   407
	r = t2.Create(KNullDesC, &Thread3, 0x1000, 0x1000, 0x1000, &d2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   408
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   409
	t2.SetPriority(EPriorityMore);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   410
	TRequestStatus s2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   411
	t2.Logon(s2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   412
	t2.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   413
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   414
	test(s1==KRequestPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   415
	test(s2==KRequestPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   416
	test(d1.iInnerLoops == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   417
	test(d2.iInnerLoops == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   418
	cvg1.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   419
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   420
	test(d2.iInnerLoops == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   421
	cvg2.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   422
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   423
	test(d2.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   424
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   425
	cvg1.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   426
	cvg2.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   427
	test(s1==KRequestPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   428
	test(s2==KRequestPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   429
	test(d1.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   430
	test(d2.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   431
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   432
	t1.Kill(0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   433
	t2.Kill(0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   434
	User::WaitForRequest(s1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   435
	User::WaitForRequest(s2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   436
	test(t1.ExitType()==EExitKill);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   437
	test(t1.ExitReason()==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   438
	test(t2.ExitType()==EExitKill);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   439
	test(t2.ExitReason()==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   440
	CLOSE_AND_WAIT(t1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   441
	CLOSE_AND_WAIT(t2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   442
	r = cvg1.OpenGlobal(TPtrC(KCondVar1Name));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   443
	test(r==KErrNotFound);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   444
	test(cvg1.Handle()==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   445
	mg1.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   446
	mg2.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   447
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   448
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   449
void TestSecondaryProcess()
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   450
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   451
	test.Next(_L("Test Secondary Process"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   452
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   453
	RProcess p;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   454
	RChunk c;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   455
	RMutex m;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   456
	RCondVar cv;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   457
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   458
	//cancel lazy dll unloading
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   459
	RLoader loader;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   460
	TInt r = loader.Connect();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   461
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   462
	r = loader.CancelLazyDllUnload();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   463
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   464
	loader.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   465
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   466
	r = c.CreateGlobal(KNullDesC, 0x1000, 0x1000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   467
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   468
	volatile TInt& x = *(volatile TInt*)c.Base();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   469
	x = 0;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   470
	r = m.CreateGlobal(KNullDesC);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   471
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   472
	r = cv.CreateGlobal(KNullDesC);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   473
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   474
	r = p.Create(RProcess().FileName(), KNullDesC);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   475
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   476
	p.SetPriority(EPriorityHigh);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   477
	r = p.SetParameter(1, cv);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   478
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   479
	r = p.SetParameter(2, m);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   480
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   481
	r = p.SetParameter(3, c);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   482
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   483
	TRequestStatus s;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   484
	p.Logon(s);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   485
	p.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   486
	test(s==KRequestPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   487
	test(x==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   488
	TInt i;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   489
	for (i=0; i<10; ++i)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   490
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   491
		cv.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   492
		test(x == i+1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   493
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   494
	cv.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   495
	test(s==KRequestPending);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   496
	test(x==10);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   497
	p.Terminate(0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   498
	User::WaitForRequest(s);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   499
	test(p.ExitType()==EExitTerminate);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   500
	test(p.ExitReason()==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   501
	CLOSE_AND_WAIT(p);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   502
	m.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   503
	c.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   504
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   505
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   506
TInt SecondaryProcess(RCondVar aCV)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   507
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   508
	RDebug::Print(_L("SecProc"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   509
	RMutex mp;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   510
	RChunk cp;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   511
	TInt r = mp.Open(2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   512
	if (r!=KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   513
		return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   514
	r = cp.Open(3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   515
	if (r!=KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   516
		return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   517
	volatile TInt& x = *(volatile TInt*)cp.Base();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   518
	mp.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   519
	r = KErrNone;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   520
	while (r==KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   521
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   522
		r = aCV.Wait(mp);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   523
		++x;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   524
		RDebug::Print(_L("SecProc r=%d x=%d"), r, x);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   525
		}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   526
	return r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   527
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   528
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   529
TInt E32Main()
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   530
	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   531
	TInt cpus = UserSvr::HalFunction(EHalGroupKernel, EKernelHalNumLogicalCpus, 0, 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   532
	if (cpus != 1)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   533
		{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   534
		test(cpus>1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   535
		// This test will require compatibility mode (and probably other changes)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   536
		// to work on SMP - it depends on explicit scheduling order.
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   537
		test.Printf(_L("T_CONDVAR skipped, does not work on SMP\n"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   538
		return KErrNone;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   539
		}	
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   540
	
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   541
	__KHEAP_MARK;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   542
	__UHEAP_MARK;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   543
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   544
	TInt r;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   545
	RCondVar cvp;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   546
	r = cvp.Open(1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   547
	if (r==KErrNone)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   548
		return SecondaryProcess(cvp);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   549
	test.Title();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   550
	test.Start(_L("Create condition variable"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   551
	r = CV1.CreateLocal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   552
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   553
	r = CV2.CreateLocal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   554
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   555
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   556
	test.Next(_L("Signal with no-one waiting"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   557
	CV1.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   558
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   559
	test.Next(_L("Broadcast with no-one waiting"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   560
	CV1.Broadcast();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   561
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   562
	test.Next(_L("Create mutexes"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   563
	r = M1.CreateLocal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   564
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   565
	r = M2.CreateLocal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   566
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   567
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   568
	RArray<TInt> array;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   569
	SThreadData d0;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   570
	d0.iM = M2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   571
	d0.iV = CV1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   572
	d0.iA = &array;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   573
	test.Next(_L("Create thread to use mutex 2"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   574
	RThread t0;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   575
	r = t0.Create(KNullDesC, &Thread1, 0x1000, 0x1000, 0x1000, &d0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   576
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   577
	t0.SetPriority(EPriorityMore);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   578
	TRequestStatus s0;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   579
	t0.Logon(s0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   580
	t0.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   581
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   582
	AppendToArray(d0, 1, 4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   583
	test(d0.iTotal==4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   584
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   585
	AppendToArray(d0, 2, -3, 17);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   586
	test(d0.iTotal==18);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   587
	t0.Terminate(11);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   588
	User::WaitForRequest(s0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   589
	test(t0.ExitType()==EExitTerminate);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   590
	test(t0.ExitReason()==11);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   591
	CLOSE_AND_WAIT(t0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   592
	array.Reset();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   593
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   594
	SThreadData d;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   595
	d.iM = M1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   596
	d.iV = CV1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   597
	d.iA = &array;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   598
	test.Next(_L("Create thread to use mutex 1"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   599
	RThread t;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   600
	r = t.Create(KNullDesC, &Thread1, 0x1000, 0x1000, 0x1000, &d);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   601
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   602
	t.SetPriority(EPriorityMore);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   603
	TRequestStatus s;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   604
	t.Logon(s);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   605
	t.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   606
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   607
	test.Next(_L("Test wait with mutex unlocked"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   608
	r = t0.Create(KNullDesC, &Thread0, 0x1000, 0x1000, 0x1000, NULL);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   609
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   610
	t0.SetPriority(EPriorityMore);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   611
	t0.Logon(s0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   612
	TBool jit = User::JustInTime();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   613
	User::SetJustInTime(EFalse);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   614
	t0.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   615
	User::WaitForRequest(s0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   616
	User::SetJustInTime(jit);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   617
	test(t0.ExitType()==EExitPanic);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   618
	test(t0.ExitCategory()==_L("KERN-EXEC"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   619
	test(t0.ExitReason()==ECondVarWaitMutexNotLocked);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   620
	CLOSE_AND_WAIT(t0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   621
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   622
	test.Next(_L("Test trying to use two mutexes with 1 condition variable"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   623
	M2.Wait();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   624
	r = CV1.Wait(M2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   625
	M2.Signal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   626
	test(r==KErrInUse);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   627
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   628
	test(d.iTotal==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   629
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   630
	AppendToArray(d, 1, 3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   631
	test(d.iTotal==3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   632
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   633
	AppendToArray(d, 2, 3, 19);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   634
	test(d.iTotal==25);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   635
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   636
	AppendToArray(d, 4, 15, -1, -2, -30);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   637
	test(d.iTotal==7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   638
	test(d.iInnerLoops==3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   639
	test(d.iOuterLoops==3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   640
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   641
	t.Suspend();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   642
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   643
	t.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   644
	test(d.iTotal==7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   645
	test(d.iInnerLoops==4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   646
	test(d.iOuterLoops==3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   647
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   648
	t.SetPriority(EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   649
	test(d.iTotal==7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   650
	test(d.iInnerLoops==4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   651
	test(d.iOuterLoops==3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   652
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   653
	t.SetPriority(EPriorityMore);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   654
	test(d.iTotal==7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   655
	test(d.iInnerLoops==5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   656
	test(d.iOuterLoops==3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   657
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   658
	t.Suspend();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   659
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   660
	AppendToArray(d, 1, 4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   661
	test(d.iTotal==7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   662
	test(d.iInnerLoops==5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   663
	test(d.iOuterLoops==3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   664
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   665
	t.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   666
	test(d.iTotal==11);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   667
	test(d.iInnerLoops==6);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   668
	test(d.iOuterLoops==4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   669
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   670
	SThreadData d2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   671
	d2.iM = M1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   672
	d2.iV = CV1;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   673
	d2.iA = &array;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   674
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   675
	test.Next(_L("Create 2nd thread"));
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   676
	RThread t2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   677
	r = t2.Create(KNullDesC, &Thread1, 0x1000, NULL, &d2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   678
	test(r==KErrNone);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   679
	t2.SetPriority(EPriorityMuchMore);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   680
	TRequestStatus s2;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   681
	t2.Logon(s2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   682
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   683
	t2.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   684
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   685
	test(d2.iTotal == 11);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   686
	test(d2.iInnerLoops == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   687
	test(d2.iOuterLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   688
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   689
	AppendToArray(d, 2, 9, 10);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   690
	test(d2.iTotal == 30);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   691
	test(d2.iInnerLoops == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   692
	test(d2.iOuterLoops == 2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   693
	test(d.iTotal==11);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   694
	test(d.iInnerLoops==6);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   695
	test(d.iOuterLoops==4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   696
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   697
	AppendToArrayB(d, 2, 20, 30);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   698
	test(d2.iTotal == 80);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   699
	test(d2.iInnerLoops == 2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   700
	test(d2.iOuterLoops == 3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   701
	test(d.iTotal == 80);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   702
	test(d.iInnerLoops == 7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   703
	test(d.iOuterLoops == 5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   704
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   705
	AppendToArrayB2(d, 2, -10, -6);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   706
	test(d2.iTotal == 64);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   707
	test(d2.iInnerLoops == 3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   708
	test(d2.iOuterLoops == 4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   709
	test(d.iTotal == 64);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   710
	test(d.iInnerLoops == 8);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   711
	test(d.iOuterLoops == 6);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   712
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   713
	t2.Suspend();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   714
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   715
	AppendToArray(d, 2, -8, -8);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   716
	test(d2.iTotal == 64);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   717
	test(d2.iInnerLoops == 3);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   718
	test(d2.iOuterLoops == 4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   719
	test(d.iTotal == 48);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   720
	test(d.iInnerLoops == 9);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   721
	test(d.iOuterLoops == 7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   722
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   723
	t2.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   724
	test(d2.iTotal == 48);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   725
	test(d2.iInnerLoops == 4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   726
	test(d2.iOuterLoops == 5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   727
	test(d.iTotal == 48);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   728
	test(d.iInnerLoops == 9);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   729
	test(d.iOuterLoops == 7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   730
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   731
	// test timeouts
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   732
	d.iTimeoutMs = 1000;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   733
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   734
	t.Suspend();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   735
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   736
	t.Resume();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   737
	test(d2.iTotal == 48);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   738
	test(d2.iInnerLoops == 4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   739
	test(d2.iOuterLoops == 5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   740
	test(d2.iTimeouts == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   741
	test(d.iTotal == 48);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   742
	test(d.iInnerLoops == 10);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   743
	test(d.iOuterLoops == 7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   744
	test(d.iTimeouts == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   745
	test(array.Append(1)==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   746
	TInt nt = 0;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   747
	do	{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   748
		if (d.iTimeouts > nt)
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   749
			{
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   750
			test(d.iTimeouts-nt == 1);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   751
			nt = d.iTimeouts;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   752
			test.Printf(_L("Timeout %d\n"), nt);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   753
			test(d2.iTotal == 48);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   754
			test(d2.iInnerLoops == 4);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   755
			test(d2.iOuterLoops == 5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   756
			test(d2.iTimeouts == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   757
			test(d.iTotal == 48+nt);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   758
			test(d.iInnerLoops == 10+nt);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   759
			test(d.iOuterLoops == 7+nt);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   760
			test(array.Append(1)==0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   761
			}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   762
		} while (nt<10);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   763
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   764
	d.iTimeoutMs = 0;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   765
	AppendToArrayB(d, 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   766
	test(d2.iTotal == 59);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   767
	test(d2.iInnerLoops == 5);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   768
	test(d2.iOuterLoops == 6);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   769
	test(d2.iTimeouts == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   770
	test(d.iTotal == 59);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   771
	test(d.iInnerLoops == 21);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   772
	test(d.iOuterLoops == 18);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   773
	test(d.iTimeouts == 10);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   774
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   775
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   776
	t.SetPriority(EPriorityLess);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   777
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   778
	AppendToArrayB(d, 1, 11);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   779
	test(d2.iTotal == 70);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   780
	test(d2.iInnerLoops == 6);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   781
	test(d2.iOuterLoops == 7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   782
	test(d2.iTimeouts == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   783
	test(d.iTotal == 59);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   784
	test(d.iInnerLoops == 21);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   785
	test(d.iOuterLoops == 18);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   786
	test(d.iTimeouts == 10);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   787
	User::After(50000);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   788
	test(d2.iTotal == 70);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   789
	test(d2.iInnerLoops == 6);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   790
	test(d2.iOuterLoops == 7);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   791
	test(d2.iTimeouts == 0);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   792
	test(d.iTotal == 70);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   793
	test(d.iInnerLoops == 22);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   794
	test(d.iOuterLoops == 19);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   795
	test(d.iTimeouts == 10);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   796
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   797
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   798
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   799
	__TRACE_LINE__;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   800
	CV1.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   801
	User::WaitForRequest(s);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   802
	test(t.ExitType()==EExitKill);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   803
	test(t.ExitReason()==KErrGeneral);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   804
	User::WaitForRequest(s2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   805
	test(t2.ExitType()==EExitKill);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   806
	test(t2.ExitReason()==KErrGeneral);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   807
	CLOSE_AND_WAIT(t);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   808
	CLOSE_AND_WAIT(t2);
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   809
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   810
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   811
	M1.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   812
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   813
	TestGlobal();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   814
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   815
	Thread2Test();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   816
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   817
	TestSecondaryProcess();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   818
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   819
	RunBench();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   820
	M2.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   821
	CV2.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   822
	array.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   823
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   824
	test.End();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   825
	test.Close();
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   826
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   827
	__UHEAP_MARKEND;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   828
	__KHEAP_MARKEND;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   829
	return KErrNone;
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   830
	}
e4a7b1cbe40c 201019_01
hgs
parents: 0
diff changeset
   831