kerneltest/e32test/benchmark/k32bm.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 15 Jul 2010 20:11:42 +0300
branchRCL_3
changeset 41 0ffb4e86fcc9
parent 0 a41df078684a
permissions -rw-r--r--
Revision: 201027 Kit: 2010127

// 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