kernel/eka/include/d32btrace.h
changeset 9 96e5fb8b040d
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kernel/eka/include/d32btrace.h	Thu Dec 17 09:24:54 2009 +0200
@@ -0,0 +1,359 @@
+// Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of the License "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+//
+// WARNING: This file contains some APIs which are internal and are subject
+//          to change without notice. Such APIs should therefore not be used
+//          outside the Kernel and Hardware Services package.
+//
+
+#ifndef D32BTRACE_H
+#define D32BTRACE_H
+
+#include <e32cmn.h>
+#include <e32ver.h>
+#include <e32btrace.h>
+
+#ifndef __KERNEL_MODE__
+#include <e32std.h>
+#endif
+
+
+class TBTraceBuffer;
+
+/**
+Interface to the fast-trace memory buffer.
+
+@publishedPartner
+@released
+*/
+class RBTrace : public RBusLogicalChannel
+	{
+public:
+	/**
+	Bit flags indicating the operational mode of the fast-trace buffer.
+	*/
+	enum TMode
+		{
+		/**
+		Flag set to enable trace to be stored in the buffer.
+		If this is not set, all trace records are discarded.
+		*/
+		EEnable			= 1<<0,
+
+		/**
+		This flag dictates the behaviour which occurs when the trace buffer is too full to
+		accomodate a new record.
+		When this flag is set, new trace records will overwrite the oldest ones.
+		When this flag is not set, new trace records are discard.
+		(This latter mode provides the best performance.)
+		*/
+		EFreeRunning	= 1<<1,
+		};
+
+#ifndef __KERNEL_MODE__
+	/**
+	Open channel to fast-trace driver.
+	Must be called before any other methods are used.
+	@return KErrNone or standard error code.
+	*/
+	IMPORT_C TInt Open();
+
+	/**
+	Close channel to fast-trace driver.
+	*/
+	IMPORT_C void Close();
+
+	/**
+	Get the current size of trace buffer.
+	@return Buffer size.
+	*/
+	IMPORT_C TInt BufferSize();
+
+	/**
+	Change size of trace buffer.
+	This causes all current data in the trace buffer to be lost.
+	If this method fails then the trace buffer may no longer exist.
+	@param aSize The size in bytes for the trace buffer.
+	@return KErrNone or standard error code.
+	*/
+	IMPORT_C TInt ResizeBuffer(TInt aSize);
+
+	/**
+	Discard all trace data.
+	*/
+	IMPORT_C void Empty();
+
+	/**
+	The chunk in which trace data returned by GetData() resides.
+	@return The chunk.
+	*/
+	inline RChunk DataChunk();
+
+	/**
+	The operational mode for fast-trace.
+	@return The current operational mode. This is bitmask of values from TMode.
+	*/
+	IMPORT_C TUint Mode();
+
+	/**
+	Set the operational mode for fast-trace.
+	Calling this method, invalidates the trace data returned by the last call to GetData().
+	@param aMode A bitmask of values from TMode.
+	*/
+	IMPORT_C void SetMode(TUint aMode);
+
+	/**
+	Set the trace filter bit for the specified category.
+	@param aCategory A category value from BTrace::TCategories.
+	@param aValue The new filter value for the category.
+				  1 means traces of this category are output, 0 means they are suppressed.
+				  Any other value will be ignored, and this method will just return the current
+				  value of the filter.
+	@return The previous value of the filter for the category, 0 or 1.
+			Or KErrNotSupported if this category is not supported by this build of the kernel.
+	*/
+	IMPORT_C TInt SetFilter(TUint aCategory, TInt aValue);
+
+	/**
+	Get the trace filter bit for the specified category.
+	@param aCategory A category value from enum BTrace::TCategory,	
+	@return The value of the filter for the category, 0 or 1,
+			or KErrNotSupported if this category is not supported by this build of the kernel.
+			(1 means traces of this category are output, 0 means they are suppressed.)
+	*/
+	inline TInt Filter(TUint aCategory);
+
+	/**
+	Set the trace secondary trace filter for the specified UID.
+
+	This method can not be used to disable a UID key if SetFilter2(TInt aGlobalFilter)
+	has been used to set the filter to pass all traces. Such attempts result in a return
+	code of KErrNotSupported.
+
+	@param aUid   The UID to filter.
+	@param aValue The new filter value for the UID.
+				  1 means traces with this UID are output, 0 means they are suppressed.
+				  Other values must not be used.
+
+	@return The previous value of the filter for the UID, 0 or 1, if operation is successful.
+			Otherwise, a negative number representing a system wide error code.
+			(E.g. KErrNoMemory.)
+	*/
+	IMPORT_C TInt SetFilter2(TUint32 aUid, TBool aValue);
+
+	/**
+	Set the secondary trace filter to include only the specified UIDs.
+	
+	@param aUids    Pointer to array of UIDs.
+	@param aNumUids Number of UID values pointer to by \a aUid.
+
+	@return KErrNone on success.
+			Otherwise, a negative number representing a system wide error code.
+			(E.g. KErrNoMemory.)
+	*/
+	IMPORT_C TInt SetFilter2(const TUint32* aUids, TInt aNumUids);
+
+	/**
+	Set the secondary trace filter to pass or reject every trace.
+	
+	@param aGlobalFilter If 0, the secondary filter will reject
+						 all traces; if 1, all traces are passed
+						 by the filter.
+						 Other values have no effect.
+
+	@return The previous value of the global filter.
+	*/
+	IMPORT_C TInt SetFilter2(TInt aGlobalFilter);
+
+	/**
+	Get the contents of the secondary trace filter.
+	
+	@param [out] aUids   Pointer to array of UIDs contained in the secondary filter.
+						Ownership of this array is passed to the caller of this
+						function, which is then responsible for deleting it.
+						If filter is empty, \a aUid equals zero.
+	@param [out] aGlobalFilter	Set to 1 if the secondary filter passes all traces.
+								Set to 0 if the secondary filter rejects all traces.
+								Set to -1 if the secondary filter operates by UIDs contained in traces.
+
+	@return Number of UIDs in returned array, if operation is successful.
+			Otherwise, a negative number representing a system wide error code.
+	*/
+	IMPORT_C TInt Filter2(TUint32*& aUids, TInt& aGlobalFilter);
+
+	/**
+	Get pointer to as much contiguous trace data as is available.
+	This data resides in the shared chunk DataChunk().
+	The data returned will always be a whole number of trace records, i.e. trace records
+	will not be split between successive calls to this method.
+	Once the data is no loger required, DataUsed() must be called.
+	This method can be called repeatedly to get more trace data. E.g.
+	@code
+		RBTrace trace;
+		TInt error = trace.Open();
+		if(error!=KErrNone)
+			return error;
+		const TInt KTraceDataBlockSize = 65536; // size of data we ideally want to process in one go
+		TUint8* data;
+		TInt size;
+		do
+			{
+			while((size=trace.GetData(data))!=0)
+				{
+				ProcessTheTraceData(data,size);
+				trace.DataUsed();
+				}
+			TRequestStatus waitStatus;
+			trace.RequestData(waitStatus,KTraceDataBlockSize);
+			User::WaitForRequest(waitStatus);
+			error = waitStatus.Int();
+			}
+		while(error==KErrNone);
+		trace.Close();
+		return error;
+	@endcode
+
+	@param aData Pointer to the first byte of trace data.
+	@return The number of bytes of trace data available at aData.
+	@see DataChunk();
+	*/
+	IMPORT_C TInt GetData(TUint8*& aData);
+
+	/**
+	Remove from the trace buffer all of the data returned by the last call to GetData().
+	*/
+	IMPORT_C void DataUsed();
+
+	/**
+	Request notification when trace data becomes available.
+	Only one outstanding request may be present at any one time.
+	@param aStatus Request status to be complete with KErrNone once data becomes available.
+	@param aSize The minimum number of bytes of trace data required.
+				 This is intended to improve performance by only signalling the client once
+				 a suitably large amount of trace data is available. However, this request
+				 may complete before this amount of trace data is available, therefore a
+				 client must be able to handle this situation.
+				 If aSize is zero or negative, then the request completes as soon as any trace
+				 data is available.
+	@panic BTRACE 0 if a previous request is still pending
+	*/
+	IMPORT_C void RequestData(TRequestStatus& aStatus, TInt aSize);
+
+	/**
+	Cancel any previous RequestData(), completing it with KErrCancel.
+	*/
+	IMPORT_C void CancelRequestData();
+
+	/**
+	@internalTechnology
+	*/
+	TBool SetSerialPortOutput(TBool aEnable);
+
+	/**
+	Controls whether Timestamp2 field is added to trace record headers.
+	*/
+	IMPORT_C TBool SetTimestamp2Enabled(TBool aEnable);
+
+#endif
+
+	/**
+	Enumeration of panic reasons for category 'BTRACE'.
+	*/
+	enum TPanic
+		{
+		ERequestAlreadyPending, /**< A call to RequestData() was made whist a request was already pending. */
+		};
+private:
+	TInt OpenChunk();
+	void CloseChunk();
+	inline static const TDesC& Name();
+
+	enum TControl
+		{
+		EOpenBuffer,
+		EResizeBuffer,
+		ESetFilter,
+		ESetFilter2,
+		ESetFilter2Array,
+		ESetFilter2Global,
+		EGetFilter2Part1,
+		EGetFilter2Part2,
+		ERequestData,
+		ECancelRequestData,
+		ESetSerialPortOutput,
+		ESetTimestamp2Enabled,
+		};
+#ifndef __KERNEL_MODE__
+	RChunk iDataChunk;
+	TBTraceBuffer* iBuffer;
+	TInt iLastGetDataSize;
+	TUint32 iSpare[4];
+#endif
+	friend class DBTraceChannel;
+	friend class DBTraceFactory;
+	friend class RBTraceAdapter;
+	};
+
+#ifndef __KERNEL_MODE__
+
+inline RChunk RBTrace::DataChunk()
+	{
+	return iDataChunk;
+	}
+
+inline TInt RBTrace::Filter(TUint aCategory)
+	{
+	return SetFilter(aCategory,-1);
+	}
+
+#endif // !__KERNEL_MODE__
+
+inline const TDesC& RBTrace::Name()
+	{
+	_LIT(KBTraceName,"btrace");
+	return KBTraceName;
+	}
+
+
+/**
+@internalComponent
+*/
+class TBTraceBuffer
+	{
+private:
+	TUint				iStart;
+	TUint				iEnd;
+	volatile TUint		iHead;
+	volatile TUint		iTail;
+	volatile TUint		iWrap;
+	volatile TUint		iGeneration;
+	volatile TUint		iMode;
+	TUint				iRecordOffsets;
+	TUint				iCopyBuffer;
+	TUint				iCopyBufferSize;
+private:
+	TInt	Data(TUint& aData, TUint& aTail);
+	TInt	Adjust(TUint aTail, TInt aSize);
+	TInt	CopyData(TUint aData, TUint aTail, TInt aSize);
+	TUint	UpdateTail(TUint32 aOld, TUint32 aNew);
+	TInt	GetData(TUint8*& aData);
+
+	friend class RBTrace;
+	friend class TBTraceBufferK;
+	friend class RBTraceAdapter;
+	};
+
+
+
+#endif