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