author | Pat Downey <patd@symbian.org> |
Wed, 01 Sep 2010 12:34:56 +0100 | |
branch | RCL_3 |
changeset 44 | 3e88ff8f41d5 |
parent 8 | 538db54a451d |
permissions | -rw-r--r-- |
0 | 1 |
// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies). |
2 |
// All rights reserved. |
|
3 |
// This component and the accompanying materials are made available |
|
4 |
// under the terms of the License "Eclipse Public License v1.0" |
|
5 |
// which accompanies this distribution, and is available |
|
6 |
// at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
7 |
// |
|
8 |
// Initial Contributors: |
|
9 |
// Nokia Corporation - initial contribution. |
|
10 |
// |
|
11 |
// Contributors: |
|
12 |
// |
|
13 |
// Description: |
|
14 |
// e32test\thread\smpsafe.cpp |
|
15 |
// |
|
16 |
// |
|
17 |
||
18 |
#include <e32std.h> |
|
19 |
#include <e32std_private.h> |
|
20 |
#include <e32atomics.h> |
|
21 |
||
22 |
IMPORT_C void DoNothingA(); |
|
23 |
IMPORT_C void DoNothingB(); |
|
24 |
IMPORT_C void DoNothingC(); |
|
25 |
IMPORT_C void DoNothingD(); |
|
26 |
IMPORT_C void DoNothingE(); |
|
27 |
||
28 |
#ifdef MAKE_DLL |
|
29 |
||
30 |
#ifdef PROVIDE_A |
|
31 |
EXPORT_C void DoNothingA() {} |
|
32 |
#endif |
|
33 |
||
34 |
#ifdef PROVIDE_B |
|
35 |
EXPORT_C void DoNothingB() { DoNothingA(); } |
|
36 |
#endif |
|
37 |
||
38 |
#ifdef PROVIDE_C |
|
39 |
EXPORT_C void DoNothingC() { DoNothingD(); DoNothingE(); } |
|
40 |
#endif |
|
41 |
||
42 |
#ifdef PROVIDE_D |
|
43 |
EXPORT_C void DoNothingD() { DoNothingC(); } |
|
44 |
#endif |
|
45 |
||
46 |
#ifdef PROVIDE_E |
|
47 |
EXPORT_C void DoNothingE() { DoNothingC(); } |
|
48 |
#endif |
|
49 |
||
50 |
#else // !MAKE_DLL |
|
51 |
||
6
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
52 |
volatile TInt Affinity; |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
53 |
RSemaphore Start; |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
54 |
RSemaphore Stop; |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
55 |
|
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
56 |
const TInt KLoopTries = 100; |
0 | 57 |
|
6
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
58 |
// This gets run in a low priority thread. Each time around the loop it waits to be told to go, |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
59 |
// then sets Affinity to 0, then tells the other thread it's done. If we're actually locked to |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
60 |
// the same processor as the main thread, however, then we won't get to run until the other thread |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
61 |
// waits for the Stop semaphore, and thus Affinity will not get set to 0 until the other thread |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
62 |
// checked it already. |
0 | 63 |
TInt AffinitySlave(TAny*) |
64 |
{ |
|
6
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
65 |
for (TInt i = KLoopTries; i>0; --i) |
0 | 66 |
{ |
6
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
67 |
Start.Wait(); |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
68 |
Affinity = 0; |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
69 |
Stop.Signal(); |
0 | 70 |
} |
6
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
71 |
return KErrNone; |
0 | 72 |
} |
73 |
||
74 |
TInt CheckAffinity() |
|
75 |
{ |
|
76 |
RThread t; |
|
77 |
TInt r = t.Create(_L("AffinitySlave"), AffinitySlave, KDefaultStackSize, NULL, NULL); |
|
78 |
if (r != KErrNone) |
|
79 |
return r; |
|
80 |
||
6
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
81 |
Start.CreateLocal(0); |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
82 |
Stop.CreateLocal(0); |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
83 |
|
0 | 84 |
TRequestStatus s; |
85 |
t.Logon(s); |
|
86 |
t.SetPriority(EPriorityLess); |
|
87 |
t.Resume(); |
|
88 |
||
8
538db54a451d
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
6
diff
changeset
|
89 |
TInt a = 1; |
6
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
90 |
for (TInt i = KLoopTries; i>0; --i) |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
91 |
{ |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
92 |
Affinity = 1; // assume we are locked to a single cpu |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
93 |
Start.Signal(); // tell the other thread to run |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
94 |
TUint32 target = User::NTickCount() + 10; |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
95 |
while (User::NTickCount() < target) |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
96 |
{ |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
97 |
// spin, waiting to see if the other thread actually *does* run |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
98 |
} |
8
538db54a451d
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
6
diff
changeset
|
99 |
a = Affinity; |
538db54a451d
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
6
diff
changeset
|
100 |
if (a == 0) |
6
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
101 |
break; |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
102 |
Stop.Wait(); // We didn't see it this time, but try again in case of scheduling fluke |
0173bcd7697c
Revision: 201001
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
0
diff
changeset
|
103 |
} |
0 | 104 |
|
105 |
t.Kill(0); |
|
106 |
User::WaitForRequest(s); |
|
107 |
t.Close(); |
|
108 |
||
8
538db54a451d
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
6
diff
changeset
|
109 |
return a; |
0 | 110 |
} |
111 |
||
112 |
#ifndef OMIT_MAIN |
|
113 |
GLDEF_C TInt E32Main() |
|
114 |
{ |
|
115 |
#ifdef USE_A |
|
116 |
DoNothingA(); |
|
117 |
#endif |
|
118 |
#ifdef USE_B |
|
119 |
DoNothingB(); |
|
120 |
#endif |
|
121 |
return CheckAffinity(); |
|
122 |
} |
|
123 |
#endif // OMIT_MAIN |
|
124 |
||
125 |
#endif |