keepalive/flextimer/server/engine/inc/flextimercontainer.h
author hgs
Mon, 24 May 2010 20:51:35 +0300
changeset 32 5c4486441ae6
permissions -rw-r--r--
201021
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
32
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
 * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
 * All rights reserved.
hgs
parents:
diff changeset
     4
 * This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
 * under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
 * which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
 *
hgs
parents:
diff changeset
     9
 * Initial Contributors:
hgs
parents:
diff changeset
    10
 * Nokia Corporation - Initial contribution
hgs
parents:
diff changeset
    11
 *
hgs
parents:
diff changeset
    12
 * Description:
hgs
parents:
diff changeset
    13
 * This class contains definition of CFlexTimerContainer.
hgs
parents:
diff changeset
    14
 *
hgs
parents:
diff changeset
    15
 */
hgs
parents:
diff changeset
    16
hgs
parents:
diff changeset
    17
// Protection against nested includes
hgs
parents:
diff changeset
    18
#ifndef FLEXTIMERCONTAINER_H
hgs
parents:
diff changeset
    19
#define FLEXTIMERCONTAINER_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
// System includes
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
// Forward declarations
hgs
parents:
diff changeset
    25
class MFlexTimerServiceCB;
hgs
parents:
diff changeset
    26
class CFlexTimerItem;
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// Class declaration
hgs
parents:
diff changeset
    29
/**
hgs
parents:
diff changeset
    30
 *  Timer container that contains list of CFlexTimerItems, means to add and
hgs
parents:
diff changeset
    31
 *  delete them and implementation of algorithms that select which timers
hgs
parents:
diff changeset
    32
 *   should be expired.
hgs
parents:
diff changeset
    33
 */
hgs
parents:
diff changeset
    34
class CFlexTimerContainer : public CBase
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
public:
hgs
parents:
diff changeset
    37
    /** Supported timer algorithms.*/
hgs
parents:
diff changeset
    38
    enum TFlexTimerAlgorithm
hgs
parents:
diff changeset
    39
        {
hgs
parents:
diff changeset
    40
        /** Simple algorithm timeouts all timers that have open timeout
hgs
parents:
diff changeset
    41
         * window when one timer expires.
hgs
parents:
diff changeset
    42
         */
hgs
parents:
diff changeset
    43
        EFlexTimerAlgorithmSimple = 1,
hgs
parents:
diff changeset
    44
        /** Latest possible algorithm tries to delay expiration of timer
hgs
parents:
diff changeset
    45
         * as long as possible.
hgs
parents:
diff changeset
    46
         */
hgs
parents:
diff changeset
    47
        EFlexTimerAlgorithmLatestPossible
hgs
parents:
diff changeset
    48
        };
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
    /**
hgs
parents:
diff changeset
    51
     * Constructs new CFlexTimerContainer.
hgs
parents:
diff changeset
    52
     */
hgs
parents:
diff changeset
    53
    static CFlexTimerContainer* NewL();
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
    /**
hgs
parents:
diff changeset
    56
     * Destructs timercontainer and all timers in the internal lists.
hgs
parents:
diff changeset
    57
     */
hgs
parents:
diff changeset
    58
    virtual ~CFlexTimerContainer();
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
public:
hgs
parents:
diff changeset
    61
    /**
hgs
parents:
diff changeset
    62
     * Makes new timer item and adds it to timerlist.
hgs
parents:
diff changeset
    63
     *
hgs
parents:
diff changeset
    64
     * @param aWinStartInterval Time interval from present to left side of the
hgs
parents:
diff changeset
    65
     *  timer launch window
hgs
parents:
diff changeset
    66
     * @param aWinEndInterval Time interval from present to right side of the
hgs
parents:
diff changeset
    67
     *  timer launch window
hgs
parents:
diff changeset
    68
     * @param aCancelAtSystemTimeChange Whether system time change should
hgs
parents:
diff changeset
    69
     *  trigger abort
hgs
parents:
diff changeset
    70
     * @param aFlexTimerServiceCB Call back interface. Used to inform about
hgs
parents:
diff changeset
    71
     *  timeout, abort etc.
hgs
parents:
diff changeset
    72
     */
hgs
parents:
diff changeset
    73
    void AddTimerL(
hgs
parents:
diff changeset
    74
        const TTimeIntervalMicroSeconds& aWinStartInterval,
hgs
parents:
diff changeset
    75
        const TTimeIntervalMicroSeconds& aWinEndInterval,
hgs
parents:
diff changeset
    76
        TBool aCancelAtSystemTimeChange,
hgs
parents:
diff changeset
    77
        const MFlexTimerServiceCB* aFlexTimerServiceCB );
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
    /**
hgs
parents:
diff changeset
    80
     * Finds correct timer according to aFlexTimerServiceCB and removes it
hgs
parents:
diff changeset
    81
     * from list and finally 
hgs
parents:
diff changeset
    82
     * deletes the corresponding CFlexTimerItem.
hgs
parents:
diff changeset
    83
     * @param aFlexTimerServiceCB Call back interface aka. session that
hgs
parents:
diff changeset
    84
     * handles timer.
hgs
parents:
diff changeset
    85
     * @return KErrNone or some system wide error code.
hgs
parents:
diff changeset
    86
     */
hgs
parents:
diff changeset
    87
    TInt RemoveTimer( const MFlexTimerServiceCB* aFlexTimerServiceCB );
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
    /**
hgs
parents:
diff changeset
    90
     * Finds earliest moment that at least one timer must expire and after
hgs
parents:
diff changeset
    91
     * this function returns aNextTimeoutDelay contains number of microseconds
hgs
parents:
diff changeset
    92
     * from now to that moment.
hgs
parents:
diff changeset
    93
     *
hgs
parents:
diff changeset
    94
     * @param after return aNextTimeoutDelay contains time in microseconds
hgs
parents:
diff changeset
    95
     * from now till next timer expiry. If aNextTimeoutDelay is zero, it means
hgs
parents:
diff changeset
    96
     * that expiry time has already passed or is due right now
hgs
parents:
diff changeset
    97
     * @return Active timers indication
hgs
parents:
diff changeset
    98
     * - ETrue if there is at least one timer in queue
hgs
parents:
diff changeset
    99
     * - EFalse if there are no timers
hgs
parents:
diff changeset
   100
     */
hgs
parents:
diff changeset
   101
    TBool GetNextTimeout( TTimeIntervalMicroSeconds& aNextTimeoutDelay );
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
    /**
hgs
parents:
diff changeset
   104
     * Fires all timers that can be fired according to algorithm that is
hgs
parents:
diff changeset
   105
     * supplied as parameter.
hgs
parents:
diff changeset
   106
     *
hgs
parents:
diff changeset
   107
     * @param aAlgorithmToBeUsed Algorithm that is used to fire timers.
hgs
parents:
diff changeset
   108
     * - EFlexTimerAlgorithmSimple
hgs
parents:
diff changeset
   109
     * - EFlexTimerAlgorithmLatestPossible
hgs
parents:
diff changeset
   110
     */
hgs
parents:
diff changeset
   111
    void FireTimers( TFlexTimerAlgorithm aAlgorithmToBeUsed );
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
    /**
hgs
parents:
diff changeset
   114
     * Aborts and removes all timers that are marked with
hgs
parents:
diff changeset
   115
     * aCancelAtSystemTimeChange = ETrue during adding timer.
hgs
parents:
diff changeset
   116
     *
hgs
parents:
diff changeset
   117
     * @param aReason Timers will be aborted with this reason code. Can be
hgs
parents:
diff changeset
   118
     * e.g. KErrAbort
hgs
parents:
diff changeset
   119
     */
hgs
parents:
diff changeset
   120
    void AbortTimersDueToTimeChange( TInt aReason );
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
private:
hgs
parents:
diff changeset
   123
    /**
hgs
parents:
diff changeset
   124
     * Private constructor.
hgs
parents:
diff changeset
   125
     */
hgs
parents:
diff changeset
   126
    CFlexTimerContainer();
hgs
parents:
diff changeset
   127
hgs
parents:
diff changeset
   128
    /**
hgs
parents:
diff changeset
   129
     * Excecutes simple algorithm.
hgs
parents:
diff changeset
   130
     * 
hgs
parents:
diff changeset
   131
     * Moves timers (that can be fired right now) from iTimerList to
hgs
parents:
diff changeset
   132
     * candidateList.
hgs
parents:
diff changeset
   133
     * 
hgs
parents:
diff changeset
   134
     * @param aCandidateList After this function returns, this list contains
hgs
parents:
diff changeset
   135
     * all timers that can be fire right now.
hgs
parents:
diff changeset
   136
     * @param aCurrentTime Current safe UTC time.
hgs
parents:
diff changeset
   137
     */
hgs
parents:
diff changeset
   138
    void SimpleAlgorithm( TSglQue<CFlexTimerItem>& aCandidateList,
hgs
parents:
diff changeset
   139
        TTime& aCurrentTime );
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
    /**
hgs
parents:
diff changeset
   142
     * Excecutes latest possible algorithm.
hgs
parents:
diff changeset
   143
     * 
hgs
parents:
diff changeset
   144
     * Moves timers (that don't necessarily be fired right now) from
hgs
parents:
diff changeset
   145
     * candidateList to iTimerList.
hgs
parents:
diff changeset
   146
     * 
hgs
parents:
diff changeset
   147
     * @param aCandidateList After this function returns, this list contains
hgs
parents:
diff changeset
   148
     * all timers that can be fire right now.
hgs
parents:
diff changeset
   149
     */
hgs
parents:
diff changeset
   150
    void LatestPossibleAlgorithm( TSglQue<CFlexTimerItem>& aCandidateList );
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
    /**
hgs
parents:
diff changeset
   153
     * Fires all timers in aCandidateList. Calls Timeout() to all timers and
hgs
parents:
diff changeset
   154
     * deletes timer items.
hgs
parents:
diff changeset
   155
     * 
hgs
parents:
diff changeset
   156
     * @param aCandidateList Timers that are fired.
hgs
parents:
diff changeset
   157
     */
hgs
parents:
diff changeset
   158
    void ExpireTimers( TSglQue<CFlexTimerItem>& aCandidateList );
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
    /**
hgs
parents:
diff changeset
   161
     * Gets current absolute time. The time in FlexTimer engine time base, not
hgs
parents:
diff changeset
   162
     * system time base. This time base is begins from the first call to
hgs
parents:
diff changeset
   163
     *  GetCurrentTime and it is base on system ticks.
hgs
parents:
diff changeset
   164
     * 
hgs
parents:
diff changeset
   165
     * @param aCurrentAbsoluteTime After this function returns this contains
hgs
parents:
diff changeset
   166
     * current flextimer timebase time.
hgs
parents:
diff changeset
   167
     */
hgs
parents:
diff changeset
   168
    void GetCurrentTime( TTime& aCurrentAbsoluteTime );
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
    /**
hgs
parents:
diff changeset
   171
     * Converts microseconds interval to tick based reference time used by
hgs
parents:
diff changeset
   172
     * FlexTimer engine (also in microseconds). All FlexTimer timeout element
hgs
parents:
diff changeset
   173
     * time handling is based on this tick based absolute time.
hgs
parents:
diff changeset
   174
     *
hgs
parents:
diff changeset
   175
     * @param aInterval Interval to be converted.
hgs
parents:
diff changeset
   176
     */
hgs
parents:
diff changeset
   177
    inline TInt64 IntervalToAbsoluteTime(
hgs
parents:
diff changeset
   178
        const TTimeIntervalMicroSeconds& aInterval );
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
    /**
hgs
parents:
diff changeset
   181
     * Converts ticks to microseconds.
hgs
parents:
diff changeset
   182
     *
hgs
parents:
diff changeset
   183
     * @param aTicks. Ticks to be converted to microseconds
hgs
parents:
diff changeset
   184
     */
hgs
parents:
diff changeset
   185
    inline TInt64 TicksToAbsoluteTime( TUint32 aTicks );
hgs
parents:
diff changeset
   186
hgs
parents:
diff changeset
   187
private:
hgs
parents:
diff changeset
   188
    // Data
hgs
parents:
diff changeset
   189
    /**
hgs
parents:
diff changeset
   190
     * Linked list and iterator for all timer objects.
hgs
parents:
diff changeset
   191
     */
hgs
parents:
diff changeset
   192
    TSglQue<CFlexTimerItem> iTimerList;
hgs
parents:
diff changeset
   193
    
hgs
parents:
diff changeset
   194
    /**
hgs
parents:
diff changeset
   195
     * Length of system tick in milliseconds. The value is read once
hgs
parents:
diff changeset
   196
     * to member variable during construction of FlexTimerContainer so that
hgs
parents:
diff changeset
   197
     * it does not need be read every time the absolute time is calculated.
hgs
parents:
diff changeset
   198
     */
hgs
parents:
diff changeset
   199
    TInt iTickPeriod;
hgs
parents:
diff changeset
   200
     
hgs
parents:
diff changeset
   201
    /**
hgs
parents:
diff changeset
   202
     * Number of tics during the last time they were read. This is used to
hgs
parents:
diff changeset
   203
     * detect possible tick counter overflow and to calculate time passed
hgs
parents:
diff changeset
   204
     * since the last read.
hgs
parents:
diff changeset
   205
     */
hgs
parents:
diff changeset
   206
    TUint32 iLastTicks;
hgs
parents:
diff changeset
   207
    
hgs
parents:
diff changeset
   208
    /**
hgs
parents:
diff changeset
   209
     * Current FlexTimer engine time. This is system tick based time and
hgs
parents:
diff changeset
   210
     * it is updated every time someone request for it.
hgs
parents:
diff changeset
   211
     */
hgs
parents:
diff changeset
   212
    TInt64 iCurrentAbsoluteTime;
hgs
parents:
diff changeset
   213
    };
hgs
parents:
diff changeset
   214
hgs
parents:
diff changeset
   215
#include "flextimercontainer.inl"
hgs
parents:
diff changeset
   216
hgs
parents:
diff changeset
   217
#endif  //FLEXTIMERCONTAINER_H