Fixes for SMP platforms
authorTom Sutcliffe <thomas.sutcliffe@accenture.com>
Fri, 30 Jul 2010 17:38:41 +0100 (2010-07-30)
changeset 22 30834c0f3179
parent 21 7b569e2061c7
child 23 092bcc217d9d
child 40 06e2064de820
Fixes for SMP platforms
commands/play/play.cif
libraries/extrabtrace/group/extrabtracek.mmp
libraries/extrabtrace/inc/extrabtracek.h
libraries/extrabtrace/src/extrabtracek.cpp
--- a/commands/play/play.cif	Fri Jul 30 14:53:31 2010 +0100
+++ b/commands/play/play.cif	Fri Jul 30 17:38:41 2010 +0100
@@ -26,7 +26,7 @@
 
 ==option int f preference
 
-Sepcifies the audio priority preferense for playback.
+Sepcifies the audio priority preference for playback.
 
 ==option int V volume
 
--- a/libraries/extrabtrace/group/extrabtracek.mmp	Fri Jul 30 14:53:31 2010 +0100
+++ b/libraries/extrabtrace/group/extrabtracek.mmp	Fri Jul 30 17:38:41 2010 +0100
@@ -25,17 +25,20 @@
 
 sourcepath		..\src
 
-#if defined(MARM)
-	#ifdef GCCE
-		// Workaround for the gcce makmake module doing weird things with -S when compiling .cia files
-		// And for GCCE.h's definition of __NAKED__ being wrong
-		source			usampler_cia.cpp
-	#else
-		source			usampler.cia
+#ifndef SMP // Sampler not supported on smp
+	#if defined(MARM)
+		#ifdef GCCE
+			// Workaround for the gcce makmake module doing weird things with -S when compiling .cia files
+			// And for GCCE.h's definition of __NAKED__ being wrong
+			source			usampler_cia.cpp
+		#else
+			source			usampler.cia
+		#endif
 	#endif
+source			sampler.cpp
 #endif
 
-source			extrabtracek.cpp sampler.cpp
+source			extrabtracek.cpp
 source			eventhandler.cpp
 
 start wins
--- a/libraries/extrabtrace/inc/extrabtracek.h	Fri Jul 30 14:53:31 2010 +0100
+++ b/libraries/extrabtrace/inc/extrabtracek.h	Fri Jul 30 17:38:41 2010 +0100
@@ -46,7 +46,9 @@
 	void MExtraBtrace_Close();
 
 public:
+#ifndef __SMP__
 	DCpuSampler* iSampler;
+#endif
 	DExtraBtraceEventHandler* iEventHandler;
 	};
 
--- a/libraries/extrabtrace/src/extrabtracek.cpp	Fri Jul 30 14:53:31 2010 +0100
+++ b/libraries/extrabtrace/src/extrabtracek.cpp	Fri Jul 30 17:38:41 2010 +0100
@@ -14,7 +14,9 @@
 #include <kern_priv.h>
 
 #include "common.h"
+#ifndef __SMP__
 #include "sampler.h"
+#endif
 #include "eventhandler.h"
 
 class DExtraBTraceChannel : public DLogicalChannelBase
@@ -38,8 +40,10 @@
 	err = Open();
 	if (err) return err;
 
+#ifndef __SMP__
 	iSampler = new DCpuSampler();
 	if (!iSampler) err = KErrNoMemory;
+#endif
 
 	if (!err) iEventHandler = new DExtraBtraceEventHandler(this);
 	if (!iEventHandler) err = KErrNoMemory;
@@ -72,18 +76,24 @@
 
 DExtraBTraceFactory::~DExtraBTraceFactory()
 	{
+#ifndef __SMP__
 	delete iSampler;
+#endif
 	delete iEventHandler;
 	}
 
 void DExtraBTraceFactory::SetCpuUsageSampling(MExtraBtrace::TCpuUsageCallback aCallbackFn)
 	{
+#ifndef __SMP__
 	iSampler->SetCpuUsageSampling(aCallbackFn);
+#endif
 	}
 
 void DExtraBTraceFactory::SetProfilingSampling(TBool aEnabled)
 	{
+#ifndef __SMP__
 	iSampler->SetProfilingSampling(aEnabled);
+#endif
 	}
 
 TAny* DExtraBTraceFactory::GetVersion(TInt /*aVersion*/)
@@ -111,10 +121,12 @@
 	return KErrNone;
 	}
 
+#ifndef __SMP__
 DCpuSampler* DExtraBTraceChannel::Sampler()
 	{
 	return static_cast<DExtraBTraceFactory*>(iDevice)->iSampler;
 	}
+#endif
 
 TInt DExtraBTraceChannel::RequestUserHandle(DThread* /*aThread*/, TOwnerType /*aType*/)
 	{
@@ -129,6 +141,9 @@
 		{
 	case EControlEnableProfiling:
 		{
+#ifdef __SMP__
+		return KErrNotSupported;
+#else
 		TInt enable = (a1 == 0) ? 0 : 1; // We still ignore the rate, currently
 		TInt err = BTrace::SetFilter(BTrace::EProfiling, enable);
 		if (err >= 0)
@@ -136,6 +151,7 @@
 			Sampler()->SetProfilingSampling(enable);
 			}
 		return err;
+#endif
 		}
 	default:
 		return KErrNotSupported;