kerneltest/e32test/system/t_atomicu.cpp
author hgs
Mon, 26 Jul 2010 10:52:56 +0100
changeset 231 75252ea6123b
child 271 dc268b18d709
permissions -rw-r--r--
201029_03
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
231
75252ea6123b 201029_03
hgs
parents:
diff changeset
     1
// Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
75252ea6123b 201029_03
hgs
parents:
diff changeset
     2
// All rights reserved.
75252ea6123b 201029_03
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
75252ea6123b 201029_03
hgs
parents:
diff changeset
     4
// under the terms of the License "Eclipse Public License v1.0"
75252ea6123b 201029_03
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
75252ea6123b 201029_03
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
75252ea6123b 201029_03
hgs
parents:
diff changeset
     7
//
75252ea6123b 201029_03
hgs
parents:
diff changeset
     8
// Initial Contributors:
75252ea6123b 201029_03
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
75252ea6123b 201029_03
hgs
parents:
diff changeset
    10
//
75252ea6123b 201029_03
hgs
parents:
diff changeset
    11
// Contributors:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    12
//
75252ea6123b 201029_03
hgs
parents:
diff changeset
    13
// Description:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    14
// e32test\system\t_atomicu.cpp
75252ea6123b 201029_03
hgs
parents:
diff changeset
    15
// Overview:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    16
// Simple test for class User atomic operations
75252ea6123b 201029_03
hgs
parents:
diff changeset
    17
// API Information:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    18
// User::SafeInc(), User::SafeDec(), User::LockedInc(),
75252ea6123b 201029_03
hgs
parents:
diff changeset
    19
// User::LockedDec()
75252ea6123b 201029_03
hgs
parents:
diff changeset
    20
// Details:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    21
// - Tests SafeInc, SafeDec, LockedInc and LockedDec
75252ea6123b 201029_03
hgs
parents:
diff changeset
    22
// functions in single thread and determines that counts
75252ea6123b 201029_03
hgs
parents:
diff changeset
    23
// match after finished
75252ea6123b 201029_03
hgs
parents:
diff changeset
    24
// - Tests SafeInc, SafeDec, LockedInc and LockedDec
75252ea6123b 201029_03
hgs
parents:
diff changeset
    25
// functions in multithreaded configuration and determines
75252ea6123b 201029_03
hgs
parents:
diff changeset
    26
// that counts match after finished
75252ea6123b 201029_03
hgs
parents:
diff changeset
    27
// Platforms/Drives/Compatibility:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    28
// All.
75252ea6123b 201029_03
hgs
parents:
diff changeset
    29
// Assumptions/Requirement/Pre-requisites:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    30
// Failures and causes:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    31
// Base Port information:
75252ea6123b 201029_03
hgs
parents:
diff changeset
    32
// 
75252ea6123b 201029_03
hgs
parents:
diff changeset
    33
//
75252ea6123b 201029_03
hgs
parents:
diff changeset
    34
75252ea6123b 201029_03
hgs
parents:
diff changeset
    35
#define __E32TEST_EXTENSION__
75252ea6123b 201029_03
hgs
parents:
diff changeset
    36
#include <e32test.h>
75252ea6123b 201029_03
hgs
parents:
diff changeset
    37
#include <e32svr.h>
75252ea6123b 201029_03
hgs
parents:
diff changeset
    38
#include <e32def.h>
75252ea6123b 201029_03
hgs
parents:
diff changeset
    39
75252ea6123b 201029_03
hgs
parents:
diff changeset
    40
LOCAL_D RTest test(_L("T_ATOMICU"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
    41
75252ea6123b 201029_03
hgs
parents:
diff changeset
    42
const TInt KMaxOps=20000;
75252ea6123b 201029_03
hgs
parents:
diff changeset
    43
#define KNumThreads 20
75252ea6123b 201029_03
hgs
parents:
diff changeset
    44
TInt gValue=0;
75252ea6123b 201029_03
hgs
parents:
diff changeset
    45
75252ea6123b 201029_03
hgs
parents:
diff changeset
    46
void TestSafeIncAndSafeDec()
75252ea6123b 201029_03
hgs
parents:
diff changeset
    47
	{
75252ea6123b 201029_03
hgs
parents:
diff changeset
    48
	gValue=0;
75252ea6123b 201029_03
hgs
parents:
diff changeset
    49
	// increasing when 0, should return 0
75252ea6123b 201029_03
hgs
parents:
diff changeset
    50
	test(User::SafeInc(gValue)==0);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    51
	// value also should be 0
75252ea6123b 201029_03
hgs
parents:
diff changeset
    52
	test(gValue==0);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    53
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
    54
	gValue=1;
75252ea6123b 201029_03
hgs
parents:
diff changeset
    55
	TInt expected=0;
75252ea6123b 201029_03
hgs
parents:
diff changeset
    56
	// gValue should vary only between 1 and 2
75252ea6123b 201029_03
hgs
parents:
diff changeset
    57
	for (TInt i=0; i<KMaxOps; i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
    58
		{
75252ea6123b 201029_03
hgs
parents:
diff changeset
    59
		expected=User::SafeInc(gValue)+1;
75252ea6123b 201029_03
hgs
parents:
diff changeset
    60
		test(expected==User::SafeDec(gValue));
75252ea6123b 201029_03
hgs
parents:
diff changeset
    61
		}
75252ea6123b 201029_03
hgs
parents:
diff changeset
    62
75252ea6123b 201029_03
hgs
parents:
diff changeset
    63
	// after running these, it should be 1
75252ea6123b 201029_03
hgs
parents:
diff changeset
    64
	test(gValue==1);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    65
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
    66
	// should stay zero after decreasing from 1 multiple times
75252ea6123b 201029_03
hgs
parents:
diff changeset
    67
	test(User::SafeDec(gValue)==1);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    68
	test(User::SafeDec(gValue)==0);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    69
	test(User::SafeDec(gValue)==0);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    70
	test(gValue==0);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    71
	}
75252ea6123b 201029_03
hgs
parents:
diff changeset
    72
75252ea6123b 201029_03
hgs
parents:
diff changeset
    73
void TestLockedIncAndLockedDec()
75252ea6123b 201029_03
hgs
parents:
diff changeset
    74
	{
75252ea6123b 201029_03
hgs
parents:
diff changeset
    75
	gValue=0;
75252ea6123b 201029_03
hgs
parents:
diff changeset
    76
	// increasing when 0, should return 0 as old value
75252ea6123b 201029_03
hgs
parents:
diff changeset
    77
	test(User::LockedInc(gValue)==0);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    78
	// new value should be 1
75252ea6123b 201029_03
hgs
parents:
diff changeset
    79
	test(gValue==1);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    80
75252ea6123b 201029_03
hgs
parents:
diff changeset
    81
	gValue=-1;
75252ea6123b 201029_03
hgs
parents:
diff changeset
    82
75252ea6123b 201029_03
hgs
parents:
diff changeset
    83
	// gValue should vary only between 1 and 2
75252ea6123b 201029_03
hgs
parents:
diff changeset
    84
	for (TInt i=0; i<KMaxOps; i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
    85
		{
75252ea6123b 201029_03
hgs
parents:
diff changeset
    86
		test((User::LockedInc(gValue)+1)==User::LockedDec(gValue));
75252ea6123b 201029_03
hgs
parents:
diff changeset
    87
		}
75252ea6123b 201029_03
hgs
parents:
diff changeset
    88
75252ea6123b 201029_03
hgs
parents:
diff changeset
    89
	// after running these, it should be back in -1
75252ea6123b 201029_03
hgs
parents:
diff changeset
    90
	test(gValue==-1);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    91
	}
75252ea6123b 201029_03
hgs
parents:
diff changeset
    92
75252ea6123b 201029_03
hgs
parents:
diff changeset
    93
TInt MultiThreadSafeIncAndSafeDec_FUNC(TAny*)
75252ea6123b 201029_03
hgs
parents:
diff changeset
    94
	{
75252ea6123b 201029_03
hgs
parents:
diff changeset
    95
	for (TInt i=0; i<KMaxOps; i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
    96
		{
75252ea6123b 201029_03
hgs
parents:
diff changeset
    97
		User::SafeInc(gValue);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    98
		User::SafeDec(gValue);
75252ea6123b 201029_03
hgs
parents:
diff changeset
    99
		}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   100
	return KErrNone;
75252ea6123b 201029_03
hgs
parents:
diff changeset
   101
	}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   102
75252ea6123b 201029_03
hgs
parents:
diff changeset
   103
TInt MultiThreadLockedIncAndLockedDec_FUNC(TAny*)
75252ea6123b 201029_03
hgs
parents:
diff changeset
   104
	{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   105
	for (TInt i=0; i<KMaxOps; i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
   106
		{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   107
		User::LockedInc(gValue);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   108
		User::LockedDec(gValue);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   109
		}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   110
	return KErrNone;
75252ea6123b 201029_03
hgs
parents:
diff changeset
   111
	}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   112
75252ea6123b 201029_03
hgs
parents:
diff changeset
   113
void MultiThreadSafeIncAndSafeDec()
75252ea6123b 201029_03
hgs
parents:
diff changeset
   114
	{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   115
	gValue=1; // start value 1
75252ea6123b 201029_03
hgs
parents:
diff changeset
   116
	RThread threads[KNumThreads];
75252ea6123b 201029_03
hgs
parents:
diff changeset
   117
	TRequestStatus stats[KNumThreads];
75252ea6123b 201029_03
hgs
parents:
diff changeset
   118
	TInt i;
75252ea6123b 201029_03
hgs
parents:
diff changeset
   119
75252ea6123b 201029_03
hgs
parents:
diff changeset
   120
	for (i=0;i<KNumThreads;i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
   121
		{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   122
		test_KErrNone(threads[i].Create(KNullDesC,MultiThreadSafeIncAndSafeDec_FUNC,KDefaultStackSize,NULL,NULL));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   123
		threads[i].Logon(stats[i]);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   124
		}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   125
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
   126
	//lets increase our priority first, so that all the threads start
75252ea6123b 201029_03
hgs
parents:
diff changeset
   127
	RThread().SetPriority(EPriorityMore);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   128
75252ea6123b 201029_03
hgs
parents:
diff changeset
   129
	test.Printf(_L("Resuming threads...\n"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   130
	for(i=0; i<KNumThreads; i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
   131
		threads[i].Resume();
75252ea6123b 201029_03
hgs
parents:
diff changeset
   132
75252ea6123b 201029_03
hgs
parents:
diff changeset
   133
	for(i=0; i<KNumThreads; i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
   134
		{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   135
		User::WaitForRequest(stats[i]);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   136
		test_KErrNone(stats[i].Int());
75252ea6123b 201029_03
hgs
parents:
diff changeset
   137
		CLOSE_AND_WAIT(threads[i]);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   138
		}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   139
75252ea6123b 201029_03
hgs
parents:
diff changeset
   140
	test.Printf(_L("...Threads finished\n"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   141
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
   142
	// back to normal
75252ea6123b 201029_03
hgs
parents:
diff changeset
   143
	RThread().SetPriority(EPriorityNormal);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   144
75252ea6123b 201029_03
hgs
parents:
diff changeset
   145
	// test that we returned to the startvalue
75252ea6123b 201029_03
hgs
parents:
diff changeset
   146
	test(gValue==1);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   147
	}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   148
75252ea6123b 201029_03
hgs
parents:
diff changeset
   149
void MultiThreadLockedIncAndLockedDec()
75252ea6123b 201029_03
hgs
parents:
diff changeset
   150
	{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   151
	gValue=-1; // set start value to -1
75252ea6123b 201029_03
hgs
parents:
diff changeset
   152
	RThread threads[KNumThreads];
75252ea6123b 201029_03
hgs
parents:
diff changeset
   153
	TRequestStatus stats[KNumThreads];
75252ea6123b 201029_03
hgs
parents:
diff changeset
   154
	TInt i;
75252ea6123b 201029_03
hgs
parents:
diff changeset
   155
75252ea6123b 201029_03
hgs
parents:
diff changeset
   156
	for (i=0;i<KNumThreads;i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
   157
		{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   158
		test_KErrNone(threads[i].Create(KNullDesC,MultiThreadLockedIncAndLockedDec_FUNC,KDefaultStackSize,NULL,NULL));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   159
		threads[i].Logon(stats[i]);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   160
		}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   161
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
   162
	//lets increase our priority first, so that all the threads start
75252ea6123b 201029_03
hgs
parents:
diff changeset
   163
	RThread().SetPriority(EPriorityMore);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   164
75252ea6123b 201029_03
hgs
parents:
diff changeset
   165
	test.Printf(_L("Resuming threads...\n"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   166
	for(i=0; i<KNumThreads; i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
   167
		threads[i].Resume();
75252ea6123b 201029_03
hgs
parents:
diff changeset
   168
75252ea6123b 201029_03
hgs
parents:
diff changeset
   169
	for(i=0; i<KNumThreads; i++)
75252ea6123b 201029_03
hgs
parents:
diff changeset
   170
		{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   171
		User::WaitForRequest(stats[i]);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   172
		test_KErrNone(stats[i].Int());
75252ea6123b 201029_03
hgs
parents:
diff changeset
   173
		CLOSE_AND_WAIT(threads[i]);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   174
		}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   175
75252ea6123b 201029_03
hgs
parents:
diff changeset
   176
	test.Printf(_L("...Threads finished\n"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   177
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
   178
	// back to normal
75252ea6123b 201029_03
hgs
parents:
diff changeset
   179
	RThread().SetPriority(EPriorityNormal);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   180
75252ea6123b 201029_03
hgs
parents:
diff changeset
   181
	// test that we returned to the startvalue
75252ea6123b 201029_03
hgs
parents:
diff changeset
   182
	test(gValue==-1);
75252ea6123b 201029_03
hgs
parents:
diff changeset
   183
	}
75252ea6123b 201029_03
hgs
parents:
diff changeset
   184
75252ea6123b 201029_03
hgs
parents:
diff changeset
   185
75252ea6123b 201029_03
hgs
parents:
diff changeset
   186
TInt E32Main()
75252ea6123b 201029_03
hgs
parents:
diff changeset
   187
	{
75252ea6123b 201029_03
hgs
parents:
diff changeset
   188
	test.Title();
75252ea6123b 201029_03
hgs
parents:
diff changeset
   189
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
   190
	test.Start(_L("Test single thread User::SafeInc and User::SafeDec"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   191
	TestSafeIncAndSafeDec();
75252ea6123b 201029_03
hgs
parents:
diff changeset
   192
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
   193
	test.Next(_L("Test single thread User::LockedInc and User::LockedDec"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   194
	TestLockedIncAndLockedDec();
75252ea6123b 201029_03
hgs
parents:
diff changeset
   195
75252ea6123b 201029_03
hgs
parents:
diff changeset
   196
	test.Next(_L("Test multiple thread User::SafeInc and User::SafeDec"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   197
	MultiThreadSafeIncAndSafeDec();
75252ea6123b 201029_03
hgs
parents:
diff changeset
   198
	
75252ea6123b 201029_03
hgs
parents:
diff changeset
   199
	test.Next(_L("Test multiple thread User::LockedInc and User::LockedDec"));
75252ea6123b 201029_03
hgs
parents:
diff changeset
   200
	MultiThreadLockedIncAndLockedDec();
75252ea6123b 201029_03
hgs
parents:
diff changeset
   201
75252ea6123b 201029_03
hgs
parents:
diff changeset
   202
	test.End();
75252ea6123b 201029_03
hgs
parents:
diff changeset
   203
75252ea6123b 201029_03
hgs
parents:
diff changeset
   204
	return KErrNone;
75252ea6123b 201029_03
hgs
parents:
diff changeset
   205
	}