/*---------------------------------------------------------------------------*
 *  pcputimer.h  *
 *                                                                           *
 *  Copyright 2007, 2008 Nuance Communciations, Inc.                               *
 *                                                                           *
 *  Licensed under the Apache License, Version 2.0 (the 'License');          *
 *  you may not use this file except in compliance with the License.         *
 *                                                                           *
 *  You may obtain a copy of the License at                                  *
 *      http://www.apache.org/licenses/LICENSE-2.0                           *
 *                                                                           *
 *  Unless required by applicable law or agreed to in writing, software      *
 *  distributed under the License is distributed on an 'AS IS' BASIS,        *
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * 
 *  See the License for the specific language governing permissions and      *
 *  limitations under the License.                                           *
 *                                                                           *
 *---------------------------------------------------------------------------*/

#ifndef PCPUTIMER_H
#define PCPUTIMER_H



#include "PortPrefix.h"
#include "ptypes.h"

/**
 * @addtogroup PCPUTimerModule PCPUTimer API functions
 *
 * @{
 */

/** Typedef */
typedef struct PCPUTimer_t PCPUTimer;

/**
 * Creates a new timer object.
 *
 * @param timer PCPUTimer handle
 * @return ESR_INVALID_ARGUMENT if timer is value it points to is null
 */
PORTABLE_API ESR_ReturnCode PCPUTimerCreate(PCPUTimer **timer);


/**
 * Destroys timer object.
 *
 * @param timer PCPUTimer handle
 * @return ESR_INVALID_ARGUMENT if timer is null
 */
PORTABLE_API ESR_ReturnCode PCPUTimerDestroy(PCPUTimer *timer);

/**
 * Starts the timer. This sets the reference time from which all new elapsed
 * time are computed.  This does not reset the elapsed time to 0.  This is
 * useful to pause the timer.
 *
 * @return ESR_INVALID_ARGUMENT if timer is null; ESR_FATAL_ERROR if OS timer is available
 */
PORTABLE_API ESR_ReturnCode PCPUTimerStart(PCPUTimer *timer);

/**
 * Stops the timer.
 *
 * @return ESR_INVALID_ARGUMENT if timer is null; ESR_FATAL_ERROR if OS timer is available
 */
PORTABLE_API ESR_ReturnCode PCPUTimerStop(PCPUTimer *timer);

/**
 * Returns the timer elapsed time.  If the Timer is in the stopped state,
 * successive calls to getElapsed() will always return the same value.  If the
 * Timer is in the started state, successive calls will return the elapsed
 * time since the last time PCPUTimerStart() was called.
 *
 * @return ESR_INVALID_ARGUMENT if timer or elapsed to is null; ESR_FATAL_ERROR if OS timer is available
 */
PORTABLE_API ESR_ReturnCode PCPUTimerGetElapsed(PCPUTimer *timer,
    asr_uint32_t* elapsed);
    
/**
 * Resets the elapsed time to 0 and resets the reference time of the Timer.
 * This effectively reset the timer in the same state it was right after
 * creation.
 *
 * @return ESR_INVALID_ARGUMENT if timer is null
 */
PORTABLE_API ESR_ReturnCode PCPUTimerReset(PCPUTimer *timer);

/**
 * @}
 */


#endif