1*35238bceSAndroid Build Coastguard Worker /*-------------------------------------------------------------------------
2*35238bceSAndroid Build Coastguard Worker * drawElements Utility Library
3*35238bceSAndroid Build Coastguard Worker * ----------------------------
4*35238bceSAndroid Build Coastguard Worker *
5*35238bceSAndroid Build Coastguard Worker * Copyright 2014 The Android Open Source Project
6*35238bceSAndroid Build Coastguard Worker *
7*35238bceSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
8*35238bceSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
9*35238bceSAndroid Build Coastguard Worker * You may obtain a copy of the License at
10*35238bceSAndroid Build Coastguard Worker *
11*35238bceSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
12*35238bceSAndroid Build Coastguard Worker *
13*35238bceSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
14*35238bceSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
15*35238bceSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16*35238bceSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
17*35238bceSAndroid Build Coastguard Worker * limitations under the License.
18*35238bceSAndroid Build Coastguard Worker *
19*35238bceSAndroid Build Coastguard Worker *//*!
20*35238bceSAndroid Build Coastguard Worker * \file
21*35238bceSAndroid Build Coastguard Worker * \brief Periodic timer test.
22*35238bceSAndroid Build Coastguard Worker *//*--------------------------------------------------------------------*/
23*35238bceSAndroid Build Coastguard Worker
24*35238bceSAndroid Build Coastguard Worker #include "deTimerTest.h"
25*35238bceSAndroid Build Coastguard Worker
26*35238bceSAndroid Build Coastguard Worker #include "deTimer.h"
27*35238bceSAndroid Build Coastguard Worker #include "deRandom.h"
28*35238bceSAndroid Build Coastguard Worker #include "deThread.h"
29*35238bceSAndroid Build Coastguard Worker
30*35238bceSAndroid Build Coastguard Worker #include <stdio.h>
31*35238bceSAndroid Build Coastguard Worker
timerCallback(void * arg)32*35238bceSAndroid Build Coastguard Worker static void timerCallback(void *arg)
33*35238bceSAndroid Build Coastguard Worker {
34*35238bceSAndroid Build Coastguard Worker volatile int *numCalls = (volatile int *)arg;
35*35238bceSAndroid Build Coastguard Worker ++(*numCalls);
36*35238bceSAndroid Build Coastguard Worker }
37*35238bceSAndroid Build Coastguard Worker
deTimer_selfTest(void)38*35238bceSAndroid Build Coastguard Worker void deTimer_selfTest(void)
39*35238bceSAndroid Build Coastguard Worker {
40*35238bceSAndroid Build Coastguard Worker const int numIters = 25;
41*35238bceSAndroid Build Coastguard Worker const int minInterval = 1;
42*35238bceSAndroid Build Coastguard Worker const int maxInterval = 100;
43*35238bceSAndroid Build Coastguard Worker const int intervalSleepMultiplier = 5;
44*35238bceSAndroid Build Coastguard Worker int iter;
45*35238bceSAndroid Build Coastguard Worker deRandom rnd;
46*35238bceSAndroid Build Coastguard Worker deTimer *timer = DE_NULL;
47*35238bceSAndroid Build Coastguard Worker volatile int numCalls = 0;
48*35238bceSAndroid Build Coastguard Worker
49*35238bceSAndroid Build Coastguard Worker deRandom_init(&rnd, 6789);
50*35238bceSAndroid Build Coastguard Worker
51*35238bceSAndroid Build Coastguard Worker timer = deTimer_create(timerCallback, (void *)&numCalls);
52*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(timer);
53*35238bceSAndroid Build Coastguard Worker
54*35238bceSAndroid Build Coastguard Worker for (iter = 0; iter < numIters; iter++)
55*35238bceSAndroid Build Coastguard Worker {
56*35238bceSAndroid Build Coastguard Worker bool isSingle = deRandom_getFloat(&rnd) < 0.25f;
57*35238bceSAndroid Build Coastguard Worker int interval = minInterval + (int)(deRandom_getUint32(&rnd) % (uint32_t)(maxInterval - minInterval + 1));
58*35238bceSAndroid Build Coastguard Worker int expectedCalls = isSingle ? 1 : intervalSleepMultiplier;
59*35238bceSAndroid Build Coastguard Worker bool scheduleOk = false;
60*35238bceSAndroid Build Coastguard Worker
61*35238bceSAndroid Build Coastguard Worker printf("Iter %d / %d: %d ms %s timer\n", iter + 1, numIters, interval, (isSingle ? "single" : "interval"));
62*35238bceSAndroid Build Coastguard Worker numCalls = 0;
63*35238bceSAndroid Build Coastguard Worker
64*35238bceSAndroid Build Coastguard Worker if (isSingle)
65*35238bceSAndroid Build Coastguard Worker scheduleOk = deTimer_scheduleSingle(timer, interval);
66*35238bceSAndroid Build Coastguard Worker else
67*35238bceSAndroid Build Coastguard Worker scheduleOk = deTimer_scheduleInterval(timer, interval);
68*35238bceSAndroid Build Coastguard Worker
69*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(scheduleOk);
70*35238bceSAndroid Build Coastguard Worker
71*35238bceSAndroid Build Coastguard Worker deSleep((uint32_t)(interval * intervalSleepMultiplier));
72*35238bceSAndroid Build Coastguard Worker deTimer_disable(timer);
73*35238bceSAndroid Build Coastguard Worker deSleep((uint32_t)interval);
74*35238bceSAndroid Build Coastguard Worker
75*35238bceSAndroid Build Coastguard Worker printf(" timer fired %d times, expected %d\n", numCalls, expectedCalls);
76*35238bceSAndroid Build Coastguard Worker DE_TEST_ASSERT(!isSingle || numCalls == 1);
77*35238bceSAndroid Build Coastguard Worker }
78*35238bceSAndroid Build Coastguard Worker
79*35238bceSAndroid Build Coastguard Worker deTimer_destroy(timer);
80*35238bceSAndroid Build Coastguard Worker }
81