kerneltest/e32test/benchmark/k32bm.h
changeset 0 a41df078684a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kerneltest/e32test/benchmark/k32bm.h	Mon Oct 19 15:55:17 2009 +0100
@@ -0,0 +1,147 @@
+// Copyright (c) 1999-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:
+//
+
+#if !defined(__K32BM_H__)
+#define __K32BM_H__
+
+#include <e32cmn.h>
+#include <kernel/kernel.h>
+#include <kernel/kern_priv.h>
+
+#include "d32bm.h"
+
+/**
+ * <code>MBMIsr</code> interface is typically implemented by the LDD that binds
+ * an ISR to the PDD interrupt source using <code>DBMPChannel::BindInterrupt(MBMIsr*)</code>. 
+ */
+class MBMIsr
+	{
+public:
+	/**
+	 * LDD-level Interrupt Service Routine interface. 
+	 * This function is called by the PDD in response to a <code>DBMPChannel::RequestInterrupt()</code> request..
+	 * 
+	 * @param aNow the current time in ticks
+	 */
+	virtual void Isr(TBMTicks aNow) = 0;
+	};
+
+/**
+ * <code>MBMInterruptLatencyIsr</code> interface is typically implemented by the LDD that binds
+ * an ISR to the PDD interrupt source using <code>DBMPChannel::BindInterrupt(MBMInterruptLatencyIsr*)</code>. 
+ */
+class MBMInterruptLatencyIsr
+	{
+public:
+	/**
+	 * LDD-level Interrupt Service Routine interface. 
+	 * This function is called by the PDD to deliver to LDD one interrupt latency measurement 
+	 * that was performed by PDD in response to a <code>DBMPChannel::RequestInterrupt()</code> request.
+	 *
+	 * @param aLatency the result in tick of one interrupt latency measurement.
+	 */
+	virtual void InterruptLatencyIsr(TBMTicks aLatency) = 0;
+	};
+
+/**
+ * The PDD interface.
+ *
+ * The caller must guarantee mutual excusion between the folloing calls:
+ *		<code>BindInterrupt(MBMIsr* aIsr)</code>
+ *		<code>BindInterrupt(MBMInterruptLatencyIsr* aIsr)</code>
+ *		<code>RequestInterrupt()</code>
+ *		<code>CancelInterrupt()</code>
+ */
+class DBMPChannel : public DBase
+	{
+public:
+	/**
+	 * Gets the high-resolution timer period
+	 *
+	 * @return timer period in ticks
+	 */
+	virtual TBMTicks TimerPeriod() = 0;
+	/**
+	 * Gets the current value of the high-resolution timer
+	 *
+	 * @return current time in ticks
+	 */
+	virtual TBMTicks TimerStamp() = 0;
+	/**
+	 * Translates high-resolution timer ticks to nanoseconds
+	 *
+	 * @param aTicks time in ticks. The implementation must truncate <code>aTicks</code> value to 
+	 *			<code>aTicks % TimerPeriod()</code> prior to translation.
+	 *
+	 * @return time in nano-seconds
+	 */
+	virtual TBMNs TimerTicksToNs(TBMTicks aTicks) = 0;
+	/**
+	 * Translates nanoseconds to high-resolution timer ticks 
+	 *
+	 * @param aNs time in nanoseconds
+	 *
+	 * @return time in ticks
+	 */
+	virtual TBMTicks TimerNsToTicks(TBMNs aNs) = 0;
+	/**
+	 * Binds an LDD-level ISR to the PDD interrupt source.
+	 *
+	 * The <code>MBMIsr::Isr()</code> handler is called by the LDD's ISR 
+	 * in response to a <code>DBMChannel::RequestInterrupt()</code> request.
+	 * 
+	 * @param aIsr points to the LDD ISR object.
+	 * 
+	 * @return KErrNone - on success;otherwise - an error code .
+	 */
+	virtual TInt BindInterrupt(MBMIsr* aIsr) = 0;
+	/**
+	 * Binds an LDD-level ISR to the PDD interrupt source.
+	 *
+	 * The <code>MBMInterruptLatencyIsr::Isr()</code> handler is called by the LDD's ISR 
+	 * in response to a <code>DBMChannel::RequestInterrupt()</code> request.
+	 * 
+	 * @param aIsr points to the LDD ISR object.
+	 * 
+	 * @return KErrNone - on success;otherwise - an error code .
+	 */	
+	virtual TInt BindInterrupt(MBMInterruptLatencyIsr* aIsr) = 0;
+	/**
+	 * Asynchronously requests an interrupt.
+	 * The implmentation must provide 
+	 * When the interrupt will actually occur the PDD ISR will call the bound LDD-level
+	 * <code>MBMIsr</code> or <code>MBMInterruptLatencyIsr</code> object. Note that only one
+	 * LDD ISR object can be bound to the PDD interrupt source at any given moment of time.
+	 */
+	virtual void RequestInterrupt() = 0;
+	/**
+	 * Cancels a possibly outstanding interrupt request.
+	 * When returns the PDD interrupt has been either occured or canceled.
+	 */
+	virtual void CancelInterrupt() = 0;
+	};
+
+
+#define BM_ASSERT(aCond) \
+	__ASSERT_DEBUG( (aCond), (Kern::Printf("Assertion '" #aCond "' failed;\nFile: '" __FILE__ "' Line: %d\n", __LINE__), Kern::Fault("BM", 0)) )
+
+enum
+	{
+	KBMLDDHighPriority = 64 - 1, // KNumPriorities - 1,
+	KBMLDDMidPriority = KBMLDDHighPriority - 1,
+	KBMLDDLowPriority  = KBMLDDMidPriority - 1,
+	};
+
+#endif