• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * TrafficMonitor.c
3  *
4  * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  *  * Redistributions of source code must retain the above copyright
12  *    notice, this list of conditions and the following disclaimer.
13  *  * Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in
15  *    the documentation and/or other materials provided with the
16  *    distribution.
17  *  * Neither the name Texas Instruments nor the names of its
18  *    contributors may be used to endorse or promote products derived
19  *    from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  */
33 
34 /***************************************************************************/
35 /*                                                                         */
36 /*              MODULE:         TrafficMonitor.c                           */
37 /*              PURPOSE:        Traffic Monitor                            */
38 /*                                                                         */
39 /***************************************************************************/
40 #define __FILE_ID__  FILE_ID_55
41 #include "TrafficMonitorAPI.h"
42 #include "TrafficMonitor.h"
43 #include "DataCtrl_Api.h"
44 #include "osApi.h"
45 #include "report.h"
46 #include "timer.h"
47 #include "DrvMainModules.h"
48 
49 
50 /* Percentage of max down events test interval to use in our "traffic down" timer */
51 #define MIN_INTERVAL_PERCENT 50
52 
53 /*#define TRAFF_TEST*/
54 #ifdef TRAFF_TEST
55 /*for TEST Function*/
56 TI_HANDLE TestTrafficMonitor;
57 TI_HANDLE TestEventTimer;
58 TI_HANDLE Alert1;
59 TI_HANDLE Alert2;
60 TI_HANDLE Alert3;
61 TI_HANDLE Alert4;
62 void PrintElertStus();
63 void TestEventFunc (TI_HANDLE hTrafficMonitor, TI_BOOL bTwdInitOccured);
64 #endif
65 
66 
67 /************************************************************************/
68 /*           Function prototype                                         */
69 /************************************************************************/
70 static void TimerMonitor_TimeOut (TI_HANDLE hTrafficMonitor, TI_BOOL bTwdInitOccured);
71 static void TrafficMonitor_updateBW(BandWidth_t *pBandWidth, TI_UINT32 uCurrentTS);
72 static TI_UINT32 TrafficMonitor_calcBW(BandWidth_t *pBandWidth, TI_UINT32 uCurrentTS);
73 static TI_BOOL isThresholdDown(TrafficAlertElement_t *AlertElement,TI_UINT32 CurrentTime);
74 static TI_BOOL isThresholdUp(TrafficAlertElement_t *AlertElement , TI_UINT32 CurrentTime);
75 static void SimpleByteAggregation(TI_HANDLE TraffElem,int Count);
76 static void SimpleFrameAggregation(TI_HANDLE TraffElem,int Count);
77 static TI_HANDLE TrafficMonitor_ExitFunc(TrafficMonitor_t *TrafficMonitor,TI_HANDLE hOs);
78 static TI_STATUS FindRstElemEntryIndex (TrafficMonitor_t *TrafficMonitor,TrafficAlertElement_t  *TrafficAlertElement,int *Index);
79 static TI_STATUS TrafficMonitor_SetMask(TrafficMonitor_t *TrafficMonitor,TrafficAlertElement_t *TrafficAlertElement,TraffEvntOptNum_t MaskType);
80 
81 static void TrafficMonitor_UpdateDownTrafficTimerState (TI_HANDLE hTrafficMonitor);
82 static void TrafficMonitor_ChangeDownTimerStatus (TI_HANDLE hTrafficMonitor, TI_UINT32 downEventsFound, TI_UINT32 minIntervalTime);
83 
84 /************************************************************************/
85 /*                      TrafficMonitor_create                           */
86 /************************************************************************/
TrafficMonitor_create(TI_HANDLE hOs)87 TI_HANDLE TrafficMonitor_create(TI_HANDLE hOs)
88 {
89     TrafficMonitor_t *TrafficMonitor;
90 
91     /* Allocate the data structure TrafficMonitor*/
92         TrafficMonitor = (TrafficMonitor_t*)os_memoryAlloc(hOs, sizeof(TrafficMonitor_t));
93         if (TrafficMonitor == NULL)
94         return NULL;
95 
96     os_memoryZero(hOs,TrafficMonitor,sizeof(TrafficMonitor_t));
97 
98 #ifdef TRAFF_TEST
99 	TestEventTimer = NULL;
100 #endif
101 
102     TrafficMonitor->hOs = hOs;
103 
104     /*Creates the list that will hold all the registered alert requests*/
105     TrafficMonitor->NotificationRegList = List_create(hOs,MAX_MONITORED_REQ,sizeof(TrafficAlertElement_t));
106     if (TrafficMonitor->NotificationRegList == NULL)
107         return TrafficMonitor_ExitFunc(TrafficMonitor,hOs);
108 
109     return (TI_HANDLE)TrafficMonitor;
110 }
111 
112 
113 /************************************************************************/
114 /*                    TrafficMonitor_ExitFunc                           */
115 /************************************************************************/
TrafficMonitor_ExitFunc(TrafficMonitor_t * TrafficMonitor,TI_HANDLE hOs)116 static TI_HANDLE TrafficMonitor_ExitFunc(TrafficMonitor_t *TrafficMonitor,TI_HANDLE hOs)
117 {
118     if (TrafficMonitor)
119     {
120         if(TrafficMonitor->hTrafficMonTimer)
121         {
122             tmr_DestroyTimer (TrafficMonitor->hTrafficMonTimer);
123         }
124         os_memoryFree(hOs, TrafficMonitor, sizeof(TrafficMonitor_t));
125     }
126     return NULL;
127 }
128 
129 
130 
131 /************************************************************************/
132 /*                    TrafficMonitor_config                             */
133 /************************************************************************/
TrafficMonitor_Init(TStadHandlesList * pStadHandles,TI_UINT32 BWwindowMs)134 void TrafficMonitor_Init (TStadHandlesList *pStadHandles, TI_UINT32 BWwindowMs)
135 {
136     TrafficMonitor_t *TrafficMonitor = (TrafficMonitor_t *)(pStadHandles->hTrafficMon);
137     TI_UINT32 uCurrTS = os_timeStampMs (TrafficMonitor->hOs);
138 
139     /* Create the base threshold timer that will serve all the down thresholds*/
140     TrafficMonitor->hTrafficMonTimer = tmr_CreateTimer (pStadHandles->hTimer);
141 
142     TrafficMonitor->Active = TI_FALSE;
143 
144     TrafficMonitor->hRxData = pStadHandles->hRxData;
145     TrafficMonitor->hTxCtrl = pStadHandles->hTxCtrl;
146     TrafficMonitor->hTimer  = pStadHandles->hTimer;
147 
148         /*Init All the bandwidth elements in the system */
149 	os_memoryZero(TrafficMonitor->hOs,&TrafficMonitor->DirectTxFrameBW,sizeof(BandWidth_t));
150 	os_memoryZero(TrafficMonitor->hOs,&TrafficMonitor->DirectRxFrameBW,sizeof(BandWidth_t));
151 	TrafficMonitor->DirectRxFrameBW.auFirstEventsTS[0] = uCurrTS;
152 	TrafficMonitor->DirectTxFrameBW.auFirstEventsTS[0] = uCurrTS;
153 
154     /*Registering to the RX module for notification.*/
155     TrafficMonitor->RxRegReqHandle = rxData_RegNotif (pStadHandles->hRxData,
156                                                       DIRECTED_FRAMES_RECV,
157                                                       TrafficMonitor_Event,
158                                                       TrafficMonitor,
159                                                       RX_TRAFF_MODULE);
160 
161     /*Registering to the TX module for notification .*/
162     TrafficMonitor->TxRegReqHandle = txCtrlParams_RegNotif (pStadHandles->hTxCtrl,
163                                                             DIRECTED_FRAMES_XFER,
164                                                             TrafficMonitor_Event,
165                                                             TrafficMonitor,
166                                                             TX_TRAFF_MODULE);
167 
168     TrafficMonitor->DownTimerEnabled = TI_FALSE;
169     TrafficMonitor->trafficDownTestIntervalPercent = MIN_INTERVAL_PERCENT;
170 
171 #ifdef TRAFF_TEST
172     TestTrafficMonitor = TrafficMonitor;
173     TestEventTimer = tmr_CreateTimer (pStadHandles->hTimer);
174     tmr_StartTimer (TestEventTimer, TestEventFunc, (TI_HANDLE)TrafficMonitor, 5000, TI_TRUE);
175 #endif
176 }
177 
178 /************************************************************************/
179 /*                TrafficMonitor_Start                                  */
180 /************************************************************************/
TrafficMonitor_Start(TI_HANDLE hTrafficMonitor)181 TI_STATUS TrafficMonitor_Start(TI_HANDLE hTrafficMonitor)
182 {
183     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
184     TrafficAlertElement_t *AlertElement;
185     TI_UINT32 CurentTime;
186 
187 
188     if(TrafficMonitor == NULL)
189         return TI_NOK;
190 
191     /*starts the bandwidth TIMER*/
192     if(!TrafficMonitor->Active) /*To prevent double call to timer start*/
193     {
194         TrafficMonitor_UpdateDownTrafficTimerState (TrafficMonitor);
195     }
196 
197     AlertElement  = (TrafficAlertElement_t*)List_GetFirst(TrafficMonitor->NotificationRegList);
198     CurentTime = os_timeStampMs(TrafficMonitor->hOs);
199 
200     /* go over all the Down elements and reload the timer*/
201     while(AlertElement)
202     {
203         if(AlertElement->CurrentState != ALERT_WAIT_FOR_RESET)
204         {
205             AlertElement->EventCounter = 0;
206             AlertElement->TimeOut = AlertElement->TimeIntervalMs + CurentTime;
207         }
208         AlertElement = (TrafficAlertElement_t*)List_GetNext(TrafficMonitor->NotificationRegList);
209     }
210     TrafficMonitor->Active = TI_TRUE;
211 
212     return TI_OK;
213 }
214 
215 
216 
217 /************************************************************************/
218 /*              TrafficMonitor_Stop                                     */
219 /************************************************************************/
TrafficMonitor_Stop(TI_HANDLE hTrafficMonitor)220 TI_STATUS TrafficMonitor_Stop(TI_HANDLE hTrafficMonitor)
221 {
222     TrafficMonitor_t       *pTrafficMonitor = (TrafficMonitor_t*)hTrafficMonitor;
223     TrafficAlertElement_t  *AlertElement;
224 
225     if (pTrafficMonitor == NULL)
226     {
227         return TI_NOK;
228     }
229 
230     if (pTrafficMonitor->Active) /*To prevent double call to timer stop*/
231     {
232 
233         pTrafficMonitor->Active = TI_FALSE;
234 
235         pTrafficMonitor->DownTimerEnabled = TI_FALSE;
236         tmr_StopTimer (pTrafficMonitor->hTrafficMonTimer);
237     }
238 
239     /* Set all events state to ALERT_OFF to enable them to "kick" again once after TrafficMonitor is started */
240     AlertElement = (TrafficAlertElement_t*)List_GetFirst(pTrafficMonitor->NotificationRegList);
241 
242     while(AlertElement)
243     {
244         AlertElement->CurrentState = ALERT_OFF;
245         AlertElement = (TrafficAlertElement_t*)List_GetNext(pTrafficMonitor->NotificationRegList);
246     }
247 
248     return TI_OK;
249 }
250 
251 
252 
253 /************************************************************************/
254 /*                  TrafficMonitor_Destroy                              */
255 /************************************************************************/
TrafficMonitor_Destroy(TI_HANDLE hTrafficMonitor)256 TI_STATUS TrafficMonitor_Destroy(TI_HANDLE hTrafficMonitor)
257 {
258     TrafficMonitor_t *TrafficMonitor = (TrafficMonitor_t*)hTrafficMonitor;
259 
260     if (TrafficMonitor)
261     {
262         /*Unregister from the RX/TX module for the required notification*/
263         txCtrlParams_UnRegNotif(TrafficMonitor->hTxCtrl,TrafficMonitor->TxRegReqHandle);
264         rxData_UnRegNotif(TrafficMonitor->hRxData,TrafficMonitor->RxRegReqHandle);
265 
266         if(TrafficMonitor->NotificationRegList)
267         {
268             List_Destroy(TrafficMonitor->NotificationRegList);
269         }
270 
271         if(TrafficMonitor->hTrafficMonTimer)
272         {
273             tmr_DestroyTimer (TrafficMonitor->hTrafficMonTimer);
274         }
275 
276 #ifdef TRAFF_TEST
277 		if (TestEventTimer)
278 		{
279 			tmr_DestroyTimer (TestEventTimer);
280 		}
281 #endif
282 
283         os_memoryFree(TrafficMonitor->hOs, TrafficMonitor, sizeof(TrafficMonitor_t));
284 
285         return TI_OK;
286     }
287 
288     return TI_NOK;
289 }
290 
291 
292 /***********************************************************************
293  *                        TrafficMonitor_RegEvent
294  ***********************************************************************
295 DESCRIPTION: Reg event processing function, Perform the following:
296 
297 
298 INPUT:          hTrafficMonitor -       Traffic Monitor the object.
299 
300             TrafficAlertRegParm -       structure which include values to set for
301                                                 the requested Alert event
302 
303             AutoResetCreate - is only relevant to edge alerts.
304                   If AutoResetCreate flag is set to true then the registration function will create a conjunction reset element automatic
305                  this reset element will be with the same threshold but opposite in direction
306 
307                  If AutoResetCreate flag is set to false then the reset element will be supplied afterward by the user with the function
308                  TrafficMonitor_SetRstCondition() the alert will not be active till the reset function will be set.
309 
310 OUTPUT:
311 
312 RETURN:     TrafficAlertElement pointer on success, NULL otherwise
313 
314 ************************************************************************/
TrafficMonitor_RegEvent(TI_HANDLE hTrafficMonitor,TrafficAlertRegParm_t * TrafficAlertRegParm,TI_BOOL AutoResetCreate)315 TI_HANDLE TrafficMonitor_RegEvent(TI_HANDLE hTrafficMonitor,TrafficAlertRegParm_t *TrafficAlertRegParm,TI_BOOL AutoResetCreate)
316 {
317     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
318     TrafficAlertElement_t  *TrafficAlertElement;
319     TI_UINT32 CurentTime ;
320 
321     if(TrafficMonitor == NULL)
322        return NULL;
323 
324     CurentTime = os_timeStampMs(TrafficMonitor->hOs);
325 
326     /*Gets a TrafficAlertElement_t memory from the list to assign to the registered request*/
327     TrafficAlertElement = (TrafficAlertElement_t*)List_AllocElement(TrafficMonitor->NotificationRegList);
328     if (TrafficAlertElement == NULL)
329     {   /* add print*/
330                 return NULL  ;
331     }
332 
333     /*Init the alert element with the registered parameters.*/
334     TrafficAlertElement->CallBack = TrafficAlertRegParm->CallBack;
335     TrafficAlertElement->Context  = TrafficAlertRegParm->Context;
336     TrafficAlertElement->Cookie  = TrafficAlertRegParm->Cookie;
337     TrafficAlertElement->Direction = TrafficAlertRegParm->Direction;
338     TrafficAlertElement->Threshold = TrafficAlertRegParm->Threshold;
339     TrafficAlertElement->Trigger = TrafficAlertRegParm->Trigger;
340     TrafficAlertElement->TimeIntervalMs = TrafficAlertRegParm->TimeIntervalMs;
341     TrafficAlertElement->TimeOut = CurentTime + TrafficAlertRegParm->TimeIntervalMs;
342     TrafficAlertElement->EventCounter = 0;
343     TrafficMonitor_SetMask(TrafficMonitor,TrafficAlertElement,TrafficAlertRegParm->MonitorType);
344 
345     TrafficAlertElement->CurrentState = ALERT_OFF;
346     TrafficAlertElement->AutoCreated = TI_FALSE;
347     TrafficAlertElement->Enabled = TI_FALSE;
348     /*In case that this is an Edge alert there is a need for a reset condition element*/
349     /*corresponding to the Alert request but opposite in the direction.*/
350     /*Note that the reset condition for this (new) reset element, is the Alert Element it self.*/
351     if(TrafficAlertElement->Trigger == TRAFF_EDGE)
352     {
353         if(AutoResetCreate)
354         {
355             /*Gets a TrafficAlertElement_t memory from the list to assign to the reset elemnt*/
356             TrafficAlertElement->ResetElment[0] = (TrafficAlertElement_t*)List_AllocElement(TrafficMonitor->NotificationRegList);
357             if( TrafficAlertElement->ResetElment[0] == NULL)
358             {
359                 List_FreeElement(TrafficMonitor->NotificationRegList,TrafficAlertElement);
360                 return NULL;
361             }
362 
363             /*
364              copy the Traffic Element init params to the reset Elemnt Except for
365              the direction and the call back that is set to null the CurrentState set to disable.
366              And the reset condition,that points to the muster alert.
367              */
368             os_memoryCopy(TrafficMonitor->hOs,TrafficAlertElement->ResetElment[0],TrafficAlertElement,sizeof(TrafficAlertElement_t));
369             TrafficAlertElement->ResetElment[0]->CallBack = NULL;
370             /*opposite in the direction from the TrafficAlertElement->Direction*/
371             if (TrafficAlertRegParm->Direction == TRAFF_UP)
372                 TrafficAlertElement->ResetElment[0]->Direction = TRAFF_DOWN;
373             else
374                 TrafficAlertElement->ResetElment[0]->Direction = TRAFF_UP;
375             TrafficAlertElement->ResetElment[0]->CurrentState = ALERT_WAIT_FOR_RESET;
376             TrafficAlertElement->ResetElment[0]->ResetElment[0] = TrafficAlertElement;
377             TrafficAlertElement->ResetElment[0]->AutoCreated = TI_TRUE;
378 
379             TrafficAlertElement->ResetElment[0]->RstWasAssigned = TI_TRUE;
380             TrafficAlertElement->RstWasAssigned = TI_TRUE;
381 
382         }
383         else/* The reset element will be supplied afterward by the user in the meanwhile disable the alert till then*/
384         {
385             TrafficAlertElement->RstWasAssigned = TI_FALSE;
386             TrafficAlertElement->CurrentState = ALERT_WAIT_FOR_RESET;
387         }
388 
389     }
390 
391     TrafficMonitor_UpdateDownTrafficTimerState (TrafficMonitor);
392 
393     return TrafficAlertElement;
394 }
395 
396 
397 /************************************************************************/
398 /*                  FindRstElemEntryIndex                               */
399 /************************************************************************/
400 /* Gets a TrafficAlertElement_t memory from the list to assign to the reset elemnt
401  * for internal use
402  ************************************************************************/
FindRstElemEntryIndex(TrafficMonitor_t * TrafficMonitor,TrafficAlertElement_t * TrafficAlertElement,int * Index)403 static TI_STATUS FindRstElemEntryIndex (TrafficMonitor_t *TrafficMonitor,TrafficAlertElement_t  *TrafficAlertElement,int *Index)
404 {
405     int i;
406     /*Find an empty Rst element entry*/
407     for(i=0;(i<MAX_RST_ELMENT_PER_ALERT) && TrafficAlertElement->ResetElment[i];i++);
408     if(i == MAX_RST_ELMENT_PER_ALERT)
409         return TI_NOK;
410     *Index  = i;
411     return TI_OK;
412 }
413 
414 /************************************************************************/
415 /*                  TrafficMonitor_SetMask                              */
416 /************************************************************************/
417 /*
418  *      Convert the Mask from the types that declared in the
419  *  TrafficMonitorAPI to the types that are used in the Rx Tx modules.
420  *  And update the TX and RX module of the new event req
421  *  Sets the aggregation function that corresponds to the specific mask type
422  ************************************************************************/
TrafficMonitor_SetMask(TrafficMonitor_t * TrafficMonitor,TrafficAlertElement_t * TrafficAlertElement,TraffEvntOptNum_t MaskType)423 static TI_STATUS TrafficMonitor_SetMask(TrafficMonitor_t *TrafficMonitor,TrafficAlertElement_t *TrafficAlertElement,TraffEvntOptNum_t MaskType)
424 {
425     TI_UINT32 TxMask = 0;
426     TI_UINT32 RxMask = 0;
427 
428    switch(MaskType) {
429    case TX_RX_DIRECTED_FRAMES:
430         TxMask = DIRECTED_FRAMES_XFER;
431         RxMask = DIRECTED_FRAMES_RECV;
432         TrafficAlertElement->ActionFunc = SimpleFrameAggregation;
433         break;
434    case TX_ALL_MSDU_FRAMES:
435         TxMask = DIRECTED_FRAMES_XFER|MULTICAST_FRAMES_XFER|BROADCAST_FRAMES_XFER;
436         TrafficAlertElement->ActionFunc = SimpleFrameAggregation;
437     break;
438    case RX_ALL_MSDU_FRAMES:
439         RxMask = DIRECTED_FRAMES_RECV|MULTICAST_FRAMES_RECV|BROADCAST_FRAMES_RECV;
440         TrafficAlertElement->ActionFunc = SimpleFrameAggregation;
441         break;
442    case TX_RX_ALL_MSDU_FRAMES:
443         TxMask = DIRECTED_FRAMES_XFER|MULTICAST_FRAMES_XFER|BROADCAST_FRAMES_XFER;
444         RxMask = DIRECTED_FRAMES_RECV|MULTICAST_FRAMES_RECV|BROADCAST_FRAMES_RECV;
445         TrafficAlertElement->ActionFunc = SimpleFrameAggregation;
446         break;
447     case TX_RX_ALL_MSDU_IN_BYTES:
448         TxMask = DIRECTED_BYTES_XFER|MULTICAST_BYTES_XFER|BROADCAST_BYTES_XFER;
449         RxMask = DIRECTED_BYTES_RECV|MULTICAST_BYTES_RECV|BROADCAST_BYTES_RECV;
450         TrafficAlertElement->ActionFunc = SimpleByteAggregation;
451         break;
452    case TX_RX_DIRECTED_IN_BYTES:
453         TxMask = DIRECTED_BYTES_XFER;
454         RxMask = DIRECTED_BYTES_RECV;
455         TrafficAlertElement->ActionFunc = SimpleByteAggregation;
456     break;
457    case TX_RX_ALL_802_11_DATA_IN_BYTES:
458         TxMask = DIRECTED_BYTES_XFER | MULTICAST_BYTES_XFER;
459         RxMask = DIRECTED_BYTES_RECV | MULTICAST_BYTES_RECV;
460         TrafficAlertElement->ActionFunc = SimpleByteAggregation;
461     break;
462    case TX_RX_ALL_802_11_DATA_FRAMES:
463         TxMask = DIRECTED_FRAMES_XFER | MULTICAST_FRAMES_XFER;
464         RxMask = DIRECTED_FRAMES_RECV | MULTICAST_FRAMES_RECV;
465         TrafficAlertElement->ActionFunc = SimpleFrameAggregation;
466     break;
467    default:
468         WLAN_OS_REPORT(("TrafficMonitor_SetMask - unknown parameter: %d\n", MaskType));
469        return TI_NOK;
470    }
471 
472 
473    if(RxMask)
474    {
475        TrafficAlertElement->MonitorMask[RX_TRAFF_MODULE] = RxMask;
476        if(rxData_AddToNotifMask(TrafficMonitor->hRxData,TrafficMonitor->RxRegReqHandle,RxMask) == TI_NOK)
477            return TI_NOK;
478    }
479 
480    if(TxMask)
481    {
482        TrafficAlertElement->MonitorMask[TX_TRAFF_MODULE] = TxMask;
483        if(txCtrlParams_AddToNotifMask(TrafficMonitor->hTxCtrl,TrafficMonitor->TxRegReqHandle,TxMask) == TI_NOK)
484            return TI_NOK;
485    }
486 
487    return TI_OK;
488 }
489 
490 
491 /***********************************************************************
492  *                        TrafficMonitor_SetRstCondition
493  ***********************************************************************
494 DESCRIPTION: Reg event processing function, Perform the following:
495              Sets the given reset element to the Alert element.
496              if MutualRst is set, then The operation is done vise versa .
497 
498 INPUT:          hTrafficMonitor -       Traffic Monitor the object.
499 
500             EventHandle -         Alert event
501 
502             ResetEventHandle  Alert Event that will be  used to as the rest for above.
503 
504             MutualRst - if the 2 elements are used to reset One another.
505 
506 NOTE        If the reset element event condition is the same as the alert element the user
507             have to check the that threshold is bigger or smaller according to the direction
508             else it can create a deadlock
509 
510 OUTPUT:
511 
512 RETURN:     TI_OK on success, TI_NOK otherwise
513 
514 ************************************************************************/
TrafficMonitor_SetRstCondition(TI_HANDLE hTrafficMonitor,TI_HANDLE EventHandle,TI_HANDLE ResetEventHandle,TI_BOOL MutualRst)515 TI_STATUS TrafficMonitor_SetRstCondition(TI_HANDLE hTrafficMonitor, TI_HANDLE EventHandle,TI_HANDLE ResetEventHandle,TI_BOOL MutualRst)
516 {
517     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
518     TrafficAlertElement_t *TrafficAlertElement = (TrafficAlertElement_t*)EventHandle;
519     TrafficAlertElement_t *TrafficResetAlertElement = (TrafficAlertElement_t*)ResetEventHandle;
520     int i,x;
521     TI_UINT32 CurentTime ;
522 
523     if((TrafficMonitor == NULL) || (EventHandle == NULL) || (TrafficResetAlertElement == NULL))
524         return TI_NOK;
525 
526 
527     CurentTime = os_timeStampMs(TrafficMonitor->hOs);
528 
529     /*
530     Check that validity of the reset condition
531     1.The reset condition is edge.
532     2.The direction is opposite from the main alert.
533     3.The threshold is bigger or smaller according to the direction
534     This condition is not checked but the user have check it else it can create a deadlock..
535     */
536     if((TrafficResetAlertElement->Trigger != TRAFF_EDGE) || (TrafficAlertElement->Trigger != TRAFF_EDGE))
537         return TI_NOK;
538     if(TrafficResetAlertElement->Direction == TrafficAlertElement->Direction)
539         return TI_NOK;
540 
541 
542     /*Find an empty Rst element entry*/
543     if(FindRstElemEntryIndex(TrafficMonitor,TrafficResetAlertElement,&i) == TI_NOK)
544         return TI_NOK;
545 
546     TrafficResetAlertElement->ResetElment[i] = TrafficAlertElement;
547 
548     /*if we know for sure that No Rst Element was assigned
549     therefore that element was in disable mode and we have to enable it.*/
550     if (!(TrafficAlertElement->RstWasAssigned))
551     {
552         TrafficAlertElement->RstWasAssigned = TI_TRUE;
553         TrafficAlertElement->CurrentState = ALERT_OFF;
554         TrafficAlertElement->TimeOut = CurentTime + TrafficAlertElement->TimeIntervalMs;
555         TrafficAlertElement->EventCounter =0;
556     }
557 
558 
559     if(MutualRst)
560     {
561       /*Find an empty Rst element entry in the TempRstAlertElement*/
562       if(FindRstElemEntryIndex(TrafficMonitor,TrafficAlertElement,&x) == TI_NOK)
563       {
564         /*this clean up is not complete*/
565         TrafficResetAlertElement->ResetElment[i] = NULL;
566         return TI_NOK;
567       }
568 
569       TrafficAlertElement->ResetElment[x] = TrafficResetAlertElement;
570       /*if know for sure that No Rst Element was assigned
571       therefore that element was in disable mode and we have to enable it.*/
572       if (!(TrafficResetAlertElement->RstWasAssigned))
573       {
574         TrafficResetAlertElement->RstWasAssigned = TI_TRUE;
575         TrafficResetAlertElement->CurrentState = ALERT_OFF;
576         TrafficResetAlertElement->TimeOut = CurentTime + TrafficAlertElement->TimeIntervalMs;
577         TrafficResetAlertElement->EventCounter = 0;
578       }
579     }
580     return TI_OK;
581 }
582 
583 
584 /************************************************************************/
585 /*               TrafficMonitor_CleanRelatedRef                         */
586 /************************************************************************/
TrafficMonitor_CleanRelatedRef(TrafficMonitor_t * TrafficMonitor,TrafficAlertElement_t * TrafficAlertElement)587 void TrafficMonitor_CleanRelatedRef(TrafficMonitor_t *TrafficMonitor,TrafficAlertElement_t *TrafficAlertElement)
588 {
589 
590     int i;
591     TrafficAlertElement_t *AlertElement  = (TrafficAlertElement_t*)List_GetFirst(TrafficMonitor->NotificationRegList);
592 
593     /* go over all the Down elements and check for alert ResetElment that ref to TrafficAlertElement*/
594     while(AlertElement)
595     {
596         for(i=0;i<MAX_RST_ELMENT_PER_ALERT;i++)
597         {
598             if(AlertElement->ResetElment[i] == TrafficAlertElement)
599                 AlertElement->ResetElment[i] = NULL;
600         }
601         AlertElement = (TrafficAlertElement_t*)List_GetNext(TrafficMonitor->NotificationRegList);
602     }
603 }
604 
605 
606 
607 /************************************************************************/
608 /*          TrafficMonitor_StopNotif                                   */
609 /************************************************************************/
TrafficMonitor_StopEventNotif(TI_HANDLE hTrafficMonitor,TI_HANDLE EventHandle)610 void TrafficMonitor_StopEventNotif(TI_HANDLE hTrafficMonitor,TI_HANDLE EventHandle)
611 {
612     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
613     TrafficAlertElement_t *TrafficAlertElement = (TrafficAlertElement_t*)EventHandle;
614 
615     if(TrafficMonitor == NULL)
616         return ;
617 
618     if(TrafficAlertElement == NULL)
619         return ;
620 
621     TrafficAlertElement->Enabled = TI_FALSE;
622     TrafficMonitor_UpdateDownTrafficTimerState (hTrafficMonitor);
623 
624 }
625 
626 
627 
628 /************************************************************************/
629 /*          TrafficMonitor_StartNotif                                   */
630 /************************************************************************/
TrafficMonitor_StartEventNotif(TI_HANDLE hTrafficMonitor,TI_HANDLE EventHandle)631 void TrafficMonitor_StartEventNotif(TI_HANDLE hTrafficMonitor, TI_HANDLE EventHandle)
632 {
633     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
634     TrafficAlertElement_t *TrafficAlertElement = (TrafficAlertElement_t*)EventHandle;
635 
636     if(TrafficMonitor == NULL)
637         return ;
638 
639     if(TrafficAlertElement == NULL)
640         return ;
641 
642     TrafficAlertElement->Enabled = TI_TRUE;
643     TrafficMonitor_UpdateDownTrafficTimerState (hTrafficMonitor);
644 }
645 
646 
647 
648 /************************************************************************/
649 /*          TrafficMonitor_StartNotif                                   */
650 /************************************************************************/
TrafficMonitor_ResetEvent(TI_HANDLE hTrafficMonitor,TI_HANDLE EventHandle)651 void TrafficMonitor_ResetEvent(TI_HANDLE hTrafficMonitor, TI_HANDLE EventHandle)
652 {
653     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
654     TrafficAlertElement_t *TrafficAlertElement = (TrafficAlertElement_t*)EventHandle;
655 
656     if(TrafficMonitor == NULL)
657         return ;
658 
659     if(TrafficAlertElement == NULL)
660         return ;
661 
662     TrafficAlertElement->CurrentState = ALERT_OFF;
663 
664     TrafficMonitor_UpdateDownTrafficTimerState (TrafficMonitor);
665 }
666 
667 
668 
669 /************************************************************************/
670 /*          TrafficMonitor_UnregEvent                                   */
671 /************************************************************************/
TrafficMonitor_UnregEvent(TI_HANDLE hTrafficMonitor,TI_HANDLE EventHandle)672 void TrafficMonitor_UnregEvent(TI_HANDLE hTrafficMonitor, TI_HANDLE EventHandle)
673 {
674     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
675     TrafficAlertElement_t *TrafficAlertElement = (TrafficAlertElement_t*)EventHandle;
676 
677     if(TrafficMonitor == NULL)
678         return ;
679 
680     /*If it was an edge alert then there can be one more alert element to free.*/
681     /*one is the alert, and the second is the reset element that corresponds to this alert*/
682     /*if it was  Auto Created*/
683     if (TrafficAlertElement->ResetElment[0])
684       if (TrafficAlertElement->ResetElment[0]->AutoCreated)
685        List_FreeElement(TrafficMonitor->NotificationRegList,TrafficAlertElement->ResetElment);
686 
687     TrafficMonitor_CleanRelatedRef(TrafficMonitor,TrafficAlertElement);
688 
689     List_FreeElement(TrafficMonitor->NotificationRegList,EventHandle);
690 
691     TrafficMonitor_UpdateDownTrafficTimerState (TrafficMonitor);
692 }
693 
694 
695 
696 /***********************************************************************
697  *                        isThresholdUp
698  ***********************************************************************
699 DESCRIPTION: Evaluate if alert element as crossed his threshold
700              if yes it operate the callback registered for this alert and take care of the alert state.
701                          For alert with UP direction the following algorithm is preformed
702              If the threshold is passed in the req time interval or less. then
703              For Level
704                 The alert mode is changed to ON & the next timeout is set to the next interval.
705              For Edge
706                 The alert mode is changed to wait for reset and the reset element is set to off.
707                 And his timeout is set
708 
709 INPUT:
710             EventHandle -         Alert event
711             CurrentTime - the current time Time stamp
712 
713 OUTPUT:
714 
715 RETURN:     If  threshold crossed TI_TRUE else False
716 
717 ************************************************************************/
isThresholdUp(TrafficAlertElement_t * AlertElement,TI_UINT32 CurrentTime)718 static TI_BOOL isThresholdUp(TrafficAlertElement_t *AlertElement , TI_UINT32 CurrentTime)
719 {
720     int i;
721 
722     if (AlertElement->TimeOut < CurrentTime)
723     {
724         AlertElement->EventCounter = AlertElement->LastCounte;
725         AlertElement->TimeOut = CurrentTime + AlertElement->TimeIntervalMs;
726     }
727 
728     if (AlertElement->EventCounter > AlertElement->Threshold)
729     {
730         AlertElement->EventCounter = 0;
731         /*Sets the new due time (time out)*/
732         AlertElement->TimeOut = CurrentTime + AlertElement->TimeIntervalMs;
733 
734         /*For Edge alert change the alert status to wait for reset and
735         The corresponding reset element from wait for reset To off.
736         That way toggling the two elements*/
737         if(AlertElement->Trigger == TRAFF_EDGE)
738         {
739             AlertElement->CurrentState = ALERT_WAIT_FOR_RESET;
740             for(i=0;i<MAX_RST_ELMENT_PER_ALERT;i++)
741             {
742                 TrafficAlertElement_t *rstElmt = AlertElement->ResetElment[i];
743                 if(rstElmt != NULL)
744                     if(rstElmt->CurrentState == ALERT_WAIT_FOR_RESET)
745                     {
746                         rstElmt->CurrentState = ALERT_OFF;
747                         rstElmt->EventCounter = 0;
748                         rstElmt->TimeOut = CurrentTime + rstElmt->TimeIntervalMs;
749                     }
750             }
751         }
752         else
753             AlertElement->CurrentState = ALERT_ON;
754 
755         /*Call the callback function*/
756         if((AlertElement->CallBack != NULL) && AlertElement->Enabled)
757             AlertElement->CallBack(AlertElement->Context,AlertElement->Cookie);
758         return TI_TRUE;
759     }
760 
761     return TI_FALSE;
762 }
763 
764 
765 
766 /***********************************************************************
767  *                        isThresholdDown
768  ***********************************************************************
769 DESCRIPTION: Evaluate if alert element as crossed his threshold
770              if yes it operate the callback registered for this alert and take care of the alert state.
771                          For alert with DOWN direction the following algorithm is preformed
772              If the threshold is passed (EventCounter < Threshold) in the req time only. then
773              For Level
774                The alert mode is changed to ON & the next timeout is set to the next interval.
775                If the alert condition will still be on.then the next alert will be in the next time interval
776             For Edge
777                The alert mode is changed to wait for reset and the reset element is set to off.
778                And his timeout is set.
779 
780 INPUT:
781             EventHandle -         Alert event
782             CurrentTime - the current time Time stamp
783 
784 OUTPUT:
785 
786 RETURN:     If threshold crossed TI_TRUE else False
787 
788 ************************************************************************/
isThresholdDown(TrafficAlertElement_t * AlertElement,TI_UINT32 CurrentTime)789 static TI_BOOL isThresholdDown(TrafficAlertElement_t *AlertElement , TI_UINT32 CurrentTime)
790 {
791     int i;
792     TI_BOOL returnVal = TI_FALSE;
793 
794     /*
795     if its end of window time.
796     */
797     if (AlertElement->TimeOut <= CurrentTime)
798     {
799         /*
800         if there was a down edge event.
801         */
802         if (AlertElement->EventCounter <= AlertElement->Threshold)
803         {
804             /*For Edge alert change the alert status to wait for reset and
805             The corresponding reset element from wait for reset To off.
806             That way toggling the two elements*/
807             if(AlertElement->Trigger == TRAFF_EDGE)
808             {
809                 AlertElement->CurrentState = ALERT_WAIT_FOR_RESET;
810                 for(i=0;i<MAX_RST_ELMENT_PER_ALERT;i++)
811                 {
812                     TrafficAlertElement_t *rstElmt = AlertElement->ResetElment[i];
813                     if(rstElmt != NULL)
814                         if(rstElmt->CurrentState == ALERT_WAIT_FOR_RESET)
815                         {
816                             rstElmt->CurrentState = ALERT_OFF;
817                             rstElmt->EventCounter = 0;
818                             rstElmt->TimeOut = CurrentTime + rstElmt->TimeIntervalMs;
819                         }
820                 }
821             }
822             else
823                 AlertElement->CurrentState = ALERT_ON;
824 
825             /*Call the callback function*/
826             if((AlertElement->CallBack != NULL) && AlertElement->Enabled)
827                 AlertElement->CallBack(AlertElement->Context,AlertElement->Cookie);
828 
829             returnVal = TI_TRUE;
830         }
831 
832         /* end of time window - clear the event counter for the new window.*/
833         AlertElement->EventCounter = 0;
834         /*Sets the new due time (time out)*/
835         AlertElement->TimeOut = CurrentTime + AlertElement->TimeIntervalMs;
836     }
837     else
838     {
839         /*
840         In case we find out that the alert condition will not Occur for this frame window,
841         therefor start a new alert examine cycle (the next farme window).
842         (Not wait till the timeout of this current frame window)
843         */
844         if(AlertElement->EventCounter > AlertElement->Threshold)
845         {
846             AlertElement->EventCounter = 0;
847             AlertElement->TimeOut = CurrentTime + AlertElement->TimeIntervalMs;
848         }
849     }
850     return returnVal;
851 }
852 
853 
854 
855 /************************************************************************/
856 /*              TimerMonitor_TimeOut                                    */
857 /************************************************************************/
858 /*
859  *      Timer function that is called for every x time interval
860  *   That will invoke a process if any down limit as occurred.
861  *
862  ************************************************************************/
TimerMonitor_TimeOut(TI_HANDLE hTrafficMonitor,TI_BOOL bTwdInitOccured)863 static void TimerMonitor_TimeOut (TI_HANDLE hTrafficMonitor, TI_BOOL bTwdInitOccured)
864 {
865 
866     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
867     TrafficAlertElement_t *AlertElement;
868     TI_UINT32 CurentTime;
869     TI_UINT32 activeTrafDownEventsNum = 0;
870     TI_UINT32 trafficDownMinTimeout = 0xFFFFFFFF;
871 
872     if(TrafficMonitor == NULL)
873         return;
874 
875     AlertElement  = (TrafficAlertElement_t*)List_GetFirst(TrafficMonitor->NotificationRegList);
876     CurentTime = os_timeStampMs(TrafficMonitor->hOs);
877 
878 
879     /* go over all the Down elements and check for alert */
880     while(AlertElement)
881     {
882         if(AlertElement->CurrentState != ALERT_WAIT_FOR_RESET)
883         {
884             if (AlertElement->Direction == TRAFF_DOWN)
885             {
886                isThresholdDown(AlertElement,CurentTime);
887             }
888         }
889 
890          if ((AlertElement->Direction == TRAFF_DOWN) && (AlertElement->Trigger == TRAFF_EDGE) && (AlertElement->CurrentState == ALERT_OFF) && (AlertElement->Enabled == TI_TRUE))
891 {
892             /* Increase counter of active traffic down events */
893             activeTrafDownEventsNum++;
894 
895             /* Search for the alert with the most short Interval time - will be used to start timer */
896             if ((AlertElement->TimeIntervalMs) < (trafficDownMinTimeout))
897                trafficDownMinTimeout = AlertElement->TimeIntervalMs;
898          }
899 
900         AlertElement = (TrafficAlertElement_t*)List_GetNext(TrafficMonitor->NotificationRegList);
901     }
902 
903    TrafficMonitor_ChangeDownTimerStatus (TrafficMonitor,activeTrafDownEventsNum,trafficDownMinTimeout);
904 
905 }
906 
907 /***********************************************************************
908  *                        TrafficMonitor_IsEventOn
909  ***********************************************************************
910 DESCRIPTION: Returns the current status of an event element.
911 
912 INPUT:      TrafficAlertElement_t
913 
914 
915 OUTPUT:    bool
916 
917 RETURN:     True = ON  false = OFF
918 
919 ************************************************************************/
TrafficMonitor_IsEventOn(TI_HANDLE EventHandle)920 TI_BOOL TrafficMonitor_IsEventOn(TI_HANDLE EventHandle)
921 {
922     TrafficAlertElement_t *TrafficAlertElement = (TrafficAlertElement_t*)EventHandle;
923 
924     if(TrafficAlertElement == NULL)
925         return TI_FALSE;
926 
927 
928     if (TrafficAlertElement->CurrentState == ALERT_OFF)
929         return TI_FALSE;
930     else
931         return TI_TRUE;
932 
933 }
934 
935 
936 
937 /***********************************************************************
938  *                        TrafficMonitor_GetFrameBandwidth
939  ***********************************************************************
940 DESCRIPTION: Returns the total direct frames in the Rx and Tx per second.
941 
942 INPUT:          hTrafficMonitor -       Traffic Monitor the object.
943 
944 
945 OUTPUT:
946 
947 RETURN:     Total BW
948 ************************************************************************/
TrafficMonitor_GetFrameBandwidth(TI_HANDLE hTrafficMonitor)949 int TrafficMonitor_GetFrameBandwidth(TI_HANDLE hTrafficMonitor)
950 {
951 	TrafficMonitor_t 	*pTrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
952 	TI_UINT32 			uCurentTS;
953 
954 	if(pTrafficMonitor == NULL)
955         return TI_NOK;
956 
957 	uCurentTS = os_timeStampMs(pTrafficMonitor->hOs);
958 
959 	/* Calculate BW for Rx & Tx */
960 	return ( TrafficMonitor_calcBW(&pTrafficMonitor->DirectRxFrameBW, uCurentTS) +
961 			 TrafficMonitor_calcBW(&pTrafficMonitor->DirectTxFrameBW, uCurentTS) );
962 }
963 
964 /***********************************************************************
965 *                        TrafficMonitor_updateBW
966 ***********************************************************************
967 DESCRIPTION: Upon receiving an event of Tx/Rx (a packet was sent or received), This function is
968 				called and performs BW calculation.
969 
970 INPUT:
971 				pBandWidth		- BW of Rx or Tx
972 				uCurrentTS		- current TS of the recent event
973 
974 OUTPUT:         pBandWidth		- updated counters and TS
975 
976 ************************************************************************/
TrafficMonitor_updateBW(BandWidth_t * pBandWidth,TI_UINT32 uCurrentTS)977 void TrafficMonitor_updateBW(BandWidth_t *pBandWidth, TI_UINT32 uCurrentTS)
978 {
979 	/* Check if we should move to the next window */
980 	if ( (uCurrentTS - pBandWidth->auFirstEventsTS[pBandWidth->uCurrentWindow]) < (SIZE_OF_WINDOW_MS) )
981 	{
982 		pBandWidth->auWindowCounter[pBandWidth->uCurrentWindow]++;
983 	}
984 	else	/* next window */
985 	{
986 		/* increment current window and mark the first event received */
987 		pBandWidth->uCurrentWindow = (pBandWidth->uCurrentWindow + 1) & CYCLIC_COUNTER_ELEMENT;
988 		pBandWidth->auFirstEventsTS[pBandWidth->uCurrentWindow] = uCurrentTS;
989 		pBandWidth->auWindowCounter[pBandWidth->uCurrentWindow] = 1;
990 	}
991 }
992 /***********************************************************************
993 *                        TrafficMonitor_calcBW
994 ***********************************************************************
995 DESCRIPTION: Returns the total direct frames in Rx or Tx.
996 			 It is called when outside module request the BW.
997 			 Calculate band width by summing up the sliding windows.
998 
999 INPUT:       pBandWidth		- BW of Rx or Tx
1000 			 uCurrentTS		- current TS
1001 
1002 RETURN:     Total BW
1003 ************************************************************************/
TrafficMonitor_calcBW(BandWidth_t * pBandWidth,TI_UINT32 uCurrentTS)1004 TI_UINT32 TrafficMonitor_calcBW(BandWidth_t *pBandWidth, TI_UINT32 uCurrentTS)
1005 {
1006 	TI_UINT32 uTotalTime = uCurrentTS - pBandWidth->auFirstEventsTS[pBandWidth->uCurrentWindow];
1007 	TI_UINT32 uTotalBW = 0;
1008 	TI_INT32  iter = (TI_INT32)pBandWidth->uCurrentWindow;
1009 	TI_INT32  iNextIter = (iter - 1) & CYCLIC_COUNTER_ELEMENT;	/* Always one less than i */
1010 
1011 	/* As long as the summed windows are less than BW_WINDOW_MS and we didn't loop the whole array */
1012 	while ( (uTotalTime < BW_WINDOW_MS) && (iNextIter != pBandWidth->uCurrentWindow))
1013 	{
1014 		uTotalBW	+= pBandWidth->auWindowCounter[iter];
1015 		/* add next window time - next loop will check if we exceeded the BW window */
1016 		uTotalTime   = uCurrentTS - pBandWidth->auFirstEventsTS[iNextIter];
1017 
1018 		iter = iNextIter;
1019 		iNextIter = (iter - 1) & CYCLIC_COUNTER_ELEMENT;
1020 	} ;
1021 
1022 	/*
1023 	 * Note that if (iNextIter == pBandWidth->uCurrentWindow) than the calculated BW could be up to
1024 	 * SIZE_OF_WINDOW_MS less than BW_WINDOW_MS
1025 	 */
1026 	return uTotalBW;
1027 }
1028 
1029 
1030 /***********************************************************************
1031  *                        TrafficMonitor_Event
1032  ***********************************************************************
1033 DESCRIPTION: this function is called for every event that was requested from the Tx or Rx
1034              The function preformes update of the all the relevant Alert in the system
1035              that corresponds to the event. checks the Alert Status due to this event.
1036 
1037 
1038 
1039 INPUT:          hTrafficMonitor -       Traffic Monitor the object.
1040 
1041             Count - evnet count.
1042             Mask - the event mask that That triggered this function.
1043 
1044             MonitorModuleType Will hold the module type from where this function was called.
1045 
1046 OUTPUT:
1047 
1048 RETURN:
1049 
1050 ************************************************************************/
TrafficMonitor_Event(TI_HANDLE hTrafficMonitor,int Count,TI_UINT16 Mask,TI_UINT32 MonitorModuleType)1051 void TrafficMonitor_Event(TI_HANDLE hTrafficMonitor,int Count,TI_UINT16 Mask,TI_UINT32 MonitorModuleType)
1052 {
1053     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
1054     TrafficAlertElement_t *AlertElement;
1055     TI_UINT32 activeTrafDownEventsNum = 0;
1056     TI_UINT32 trafficDownMinTimeout = 0xFFFFFFFF;
1057     TI_UINT32 uCurentTS;
1058 
1059     if(TrafficMonitor == NULL)
1060         return;
1061 
1062     if(!TrafficMonitor->Active)
1063         return;
1064 
1065 	uCurentTS = os_timeStampMs(TrafficMonitor->hOs);
1066 
1067     /* for BW calculation */
1068     if(MonitorModuleType == RX_TRAFF_MODULE)
1069     {
1070         if(Mask & DIRECTED_FRAMES_RECV)
1071 		{
1072             TrafficMonitor_updateBW(&TrafficMonitor->DirectRxFrameBW, uCurentTS);
1073 		}
1074     }
1075     else if (MonitorModuleType == TX_TRAFF_MODULE)
1076     {
1077         if(Mask & DIRECTED_FRAMES_XFER)
1078 		{
1079             TrafficMonitor_updateBW(&TrafficMonitor->DirectTxFrameBW, uCurentTS);
1080 		}
1081     }
1082     else
1083 	{
1084         return; /* module type does not exist, error return */
1085 	}
1086 
1087     AlertElement  = (TrafficAlertElement_t*)List_GetFirst(TrafficMonitor->NotificationRegList);
1088 
1089     /* go over all the elements and check for alert */
1090     while(AlertElement)
1091     {
1092         if(AlertElement->CurrentState != ALERT_WAIT_FOR_RESET)
1093         {
1094             if(AlertElement->MonitorMask[MonitorModuleType] & Mask)
1095             {
1096                 AlertElement->ActionFunc(AlertElement,Count);
1097                 if (AlertElement->Direction == TRAFF_UP)
1098                 {
1099                     isThresholdUp(AlertElement, uCurentTS);
1100                 }
1101             }
1102 
1103             if ((AlertElement->Direction == TRAFF_DOWN) && (AlertElement->Trigger == TRAFF_EDGE) && (AlertElement->CurrentState == ALERT_OFF) && (AlertElement->Enabled == TI_TRUE))
1104             {
1105                /* Increase counter of active traffic down events */
1106                activeTrafDownEventsNum++;
1107 
1108                /* Search for the alert with the most short Interval time - will be used to start timer */
1109                if ((AlertElement->TimeIntervalMs) < (trafficDownMinTimeout))
1110                   trafficDownMinTimeout = AlertElement->TimeIntervalMs;
1111             }
1112 
1113         }
1114         AlertElement = (TrafficAlertElement_t*)List_GetNext(TrafficMonitor->NotificationRegList);
1115     }
1116 
1117     TrafficMonitor_ChangeDownTimerStatus (TrafficMonitor,activeTrafDownEventsNum,trafficDownMinTimeout);
1118 
1119 }
1120 
1121 
1122 /*
1123  *      Used as the aggregation function that is used by the alerts for counting the events.
1124  */
SimpleByteAggregation(TI_HANDLE TraffElem,int Count)1125 static void SimpleByteAggregation(TI_HANDLE TraffElem,int Count)
1126 {
1127     TrafficAlertElement_t *AlertElement = TraffElem;
1128     AlertElement->EventCounter += Count;
1129     AlertElement->LastCounte = Count;
1130 }
1131 
1132 
1133 /*
1134  *      Used as the aggregation function for frame. (count is not used)
1135  */
SimpleFrameAggregation(TI_HANDLE TraffElem,int Count)1136 static void SimpleFrameAggregation(TI_HANDLE TraffElem,int Count)
1137 {
1138     TrafficAlertElement_t *AlertElement = TraffElem;
1139     AlertElement->EventCounter++;
1140     AlertElement->LastCounte = 1;
1141 }
1142 
1143 /*-----------------------------------------------------------------------------
1144 Routine Name: TrafficMonitor_UpdateDownTrafficTimerState
1145 Routine Description: called whenever a "down" alert is called, or any other change in the alert list.
1146                      used to either start or stop the "traffic down" timer.
1147                      loops through alert list, searches for active traffic down events.
1148 Arguments:
1149 Return Value:
1150 -----------------------------------------------------------------------------*/
TrafficMonitor_UpdateDownTrafficTimerState(TI_HANDLE hTrafficMonitor)1151 static void TrafficMonitor_UpdateDownTrafficTimerState (TI_HANDLE hTrafficMonitor)
1152 {
1153 	TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
1154     TrafficAlertElement_t *AlertElement;
1155     TI_UINT32 activeTrafDownEventsNum = 0;
1156     TI_UINT32 trafficDownMinTimeout = 0xFFFFFFFF;
1157 
1158     AlertElement  = (TrafficAlertElement_t*)List_GetFirst(TrafficMonitor->NotificationRegList);
1159 
1160     while(AlertElement)
1161     {
1162 
1163       if ((AlertElement->Direction == TRAFF_DOWN) && (AlertElement->Trigger == TRAFF_EDGE) && (AlertElement->CurrentState == ALERT_OFF) && (AlertElement->Enabled == TI_TRUE))
1164       {
1165          /* Increase counter of active traffic down events */
1166          activeTrafDownEventsNum++;
1167 
1168          /* Search for the alert with the most short Interval time - will be used to start timer */
1169          if ((AlertElement->TimeIntervalMs) < (trafficDownMinTimeout))
1170             trafficDownMinTimeout = AlertElement->TimeIntervalMs;
1171       }
1172 
1173       AlertElement = (TrafficAlertElement_t*)List_GetNext(TrafficMonitor->NotificationRegList);
1174 
1175     }
1176 
1177     TrafficMonitor_ChangeDownTimerStatus (TrafficMonitor,activeTrafDownEventsNum,trafficDownMinTimeout);
1178 
1179 }
1180 
1181 /*-----------------------------------------------------------------------------
1182 Routine Name: TrafficMonitor_ChangeDownTimerStatus
1183 Routine Description: Start or stop down traffic timer according to number of down events found and minInterval time.
1184 Arguments:
1185 Return Value:
1186 -----------------------------------------------------------------------------*/
TrafficMonitor_ChangeDownTimerStatus(TI_HANDLE hTrafficMonitor,TI_UINT32 downEventsFound,TI_UINT32 minIntervalTime)1187 static void TrafficMonitor_ChangeDownTimerStatus (TI_HANDLE hTrafficMonitor, TI_UINT32 downEventsFound, TI_UINT32 minIntervalTime)
1188 {
1189 	TrafficMonitor_t *pTrafficMonitor = (TrafficMonitor_t*)hTrafficMonitor;
1190 
1191     if ((downEventsFound == 0) && pTrafficMonitor->DownTimerEnabled)
1192     {
1193         pTrafficMonitor->DownTimerEnabled = TI_FALSE;
1194         tmr_StopTimer (pTrafficMonitor->hTrafficMonTimer);
1195         os_wake_unlock(pTrafficMonitor->hOs);
1196     }
1197     else if ((downEventsFound > 0) && (pTrafficMonitor->DownTimerEnabled == TI_FALSE))
1198     {
1199         os_wake_lock(pTrafficMonitor->hOs);
1200         pTrafficMonitor->DownTimerEnabled = TI_TRUE;
1201         /* Start the timer with user defined percentage of the the minimum interval discovered earlier */
1202         tmr_StartTimer (pTrafficMonitor->hTrafficMonTimer,
1203                         TimerMonitor_TimeOut,
1204                         (TI_HANDLE)pTrafficMonitor,
1205                         ((minIntervalTime * pTrafficMonitor->trafficDownTestIntervalPercent) / 100),
1206                         TI_TRUE);
1207     }
1208 }
1209 
1210 #ifdef TI_DBG
1211 
1212 /*-----------------------------------------------------------------------------
1213 Routine Name: TrafficMonitor_UpdateActiveEventsCounters
1214 Routine Description:
1215 Arguments:
1216 Return Value:
1217 -----------------------------------------------------------------------------*/
TrafficMonitor_UpdateActiveEventsCounters(TI_HANDLE hTrafficMonitor)1218 void TrafficMonitor_UpdateActiveEventsCounters (TI_HANDLE hTrafficMonitor)
1219 {
1220 	TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)hTrafficMonitor;
1221     TrafficAlertElement_t *AlertElement;
1222     TI_UINT32 activeTrafDownEventsNum = 0;
1223 
1224     AlertElement  = (TrafficAlertElement_t*)List_GetFirst(TrafficMonitor->NotificationRegList);
1225 
1226     while(AlertElement)
1227     {
1228       if ((AlertElement->Direction == TRAFF_DOWN) && (AlertElement->Trigger == TRAFF_EDGE) && (AlertElement->CurrentState == ALERT_OFF) && (AlertElement->Enabled == TI_TRUE))
1229       {
1230          activeTrafDownEventsNum++;
1231       }
1232       AlertElement = (TrafficAlertElement_t*)List_GetNext(TrafficMonitor->NotificationRegList);
1233     }
1234 
1235 }
1236 
1237 
1238 #endif
1239 
1240 #ifdef TRAFF_TEST
1241 /*
1242  *      TEST Function
1243  */
func1(TI_HANDLE Context,TI_UINT32 Cookie)1244 void func1(TI_HANDLE Context,TI_UINT32 Cookie)
1245 {
1246     switch(Cookie) {
1247     case 1:
1248                 WLAN_OS_REPORT(("TRAFF - ALERT UP limit - 50 ON"));
1249         break;
1250     case 2:
1251                 WLAN_OS_REPORT(("TRAFF - ALERT UP limit - 30 ON"));
1252     break;
1253     case 3:
1254                 WLAN_OS_REPORT(("TRAFF - ALERT DOWN limit - 25 ON"));
1255     break;
1256     case 4:
1257                 WLAN_OS_REPORT(("TRAFF - ALERT DOWN limit - 10 ON"));
1258     break;
1259    }
1260 
1261 }
1262 
1263 
PrintElertStus()1264 void PrintElertStus()
1265 {
1266     TrafficMonitor_t *TrafficMonitor =(TrafficMonitor_t*)TestTrafficMonitor;
1267     TrafficAlertElement_t *AlertElement  = (TrafficAlertElement_t*)List_GetFirst(TrafficMonitor->NotificationRegList);
1268 
1269     /* go over all the Down elements and check for alert ResetElment that ref to TrafficAlertElement*/
1270     while(AlertElement)
1271     {
1272         if(AlertElement->CurrentState == ALERT_WAIT_FOR_RESET)
1273             WLAN_OS_REPORT(("TRAFF - ALERT ALERT_WAIT_FOR_RESET"));
1274         else
1275             WLAN_OS_REPORT(("TRAFF - ALERT ENABLED"));
1276 
1277 
1278         AlertElement = (TrafficAlertElement_t*)List_GetNext(TrafficMonitor->NotificationRegList);
1279     }
1280 }
1281 
TestEventFunc(TI_HANDLE hTrafficMonitor,TI_BOOL bTwdInitOccured)1282 void TestEventFunc (TI_HANDLE hTrafficMonitor, TI_BOOL bTwdInitOccured)
1283 {
1284 
1285     static flag = TI_TRUE;
1286     TrafficAlertRegParm_t TrafficAlertRegParm ;
1287     if(flag)
1288     {
1289 
1290         TrafficAlertRegParm.CallBack = func1;
1291         TrafficAlertRegParm.Context = NULL ;
1292         TrafficAlertRegParm.Cookie =  1 ;
1293         TrafficAlertRegParm.Direction = TRAFF_UP ;
1294         TrafficAlertRegParm.Trigger = TRAFF_EDGE;
1295         TrafficAlertRegParm.TimeIntervalMs = 1000;
1296         TrafficAlertRegParm.Threshold = 50;
1297         TrafficAlertRegParm.MonitorType = TX_RX_DIRECTED_FRAMES;
1298         Alert1 = TrafficMonitor_RegEvent(TestTrafficMonitor,&TrafficAlertRegParm,TI_FALSE);
1299 
1300         TrafficAlertRegParm.CallBack = func1;
1301         TrafficAlertRegParm.Context = NULL ;
1302         TrafficAlertRegParm.Cookie =  2 ;
1303         TrafficAlertRegParm.Direction = TRAFF_UP ;
1304         TrafficAlertRegParm.Trigger = TRAFF_EDGE;
1305         TrafficAlertRegParm.TimeIntervalMs = 1000;
1306         TrafficAlertRegParm.Threshold = 30;
1307         TrafficAlertRegParm.MonitorType = TX_RX_DIRECTED_FRAMES;
1308         Alert2 = TrafficMonitor_RegEvent(TestTrafficMonitor,&TrafficAlertRegParm,TI_FALSE);
1309 
1310 
1311         TrafficAlertRegParm.CallBack = func1;
1312         TrafficAlertRegParm.Context = NULL ;
1313         TrafficAlertRegParm.Cookie =  3 ;
1314         TrafficAlertRegParm.Direction = TRAFF_DOWN ;
1315         TrafficAlertRegParm.Trigger = TRAFF_EDGE;
1316         TrafficAlertRegParm.TimeIntervalMs = 1000;
1317         TrafficAlertRegParm.Threshold = 25;
1318         TrafficAlertRegParm.MonitorType = TX_RX_DIRECTED_FRAMES;
1319         Alert3 = TrafficMonitor_RegEvent(TestTrafficMonitor,&TrafficAlertRegParm,TI_FALSE);
1320 
1321         TrafficAlertRegParm.CallBack = func1;
1322         TrafficAlertRegParm.Context = NULL ;
1323         TrafficAlertRegParm.Cookie =  4 ;
1324         TrafficAlertRegParm.Direction = TRAFF_DOWN ;
1325         TrafficAlertRegParm.Trigger = TRAFF_LEVEL;
1326         TrafficAlertRegParm.TimeIntervalMs = 1000;
1327         TrafficAlertRegParm.Threshold = 10;
1328         TrafficAlertRegParm.MonitorType = TX_RX_DIRECTED_FRAMES;
1329         Alert4 = TrafficMonitor_RegEvent(TestTrafficMonitor,&TrafficAlertRegParm,TI_FALSE);
1330 
1331        TrafficMonitor_SetRstCondition(TestTrafficMonitor, Alert1,Alert3,TI_TRUE);
1332        TrafficMonitor_SetRstCondition(TestTrafficMonitor, Alert2,Alert3,TI_FALSE);
1333        flag = TI_FALSE;
1334     }
1335 
1336     PrintElertStus();
1337 
1338 }
1339 
1340 #endif
1341