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