• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /* //device/apps/Quake/quake/src/QW/client/main.c
2 **
3 ** Copyright 2007, The Android Open Source Project
4 **
5 ** Licensed under the Apache License, Version 2.0 (the "License");
6 ** you may not use this file except in compliance with the License.
7 ** You may obtain a copy of the License at
8 **
9 **     http://www.apache.org/licenses/LICENSE-2.0
10 **
11 ** Unless required by applicable law or agreed to in writing, software
12 ** distributed under the License is distributed on an "AS IS" BASIS,
13 ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 ** See the License for the specific language governing permissions and
15 ** limitations under the License.
16 */
17 
18 #include <stdio.h>
19 #include <assert.h>
20 
21 #define LOG_TAG "Quake"
22 
23 #include <GLES/gl.h>
24 #include <utils/Log.h>
25 #include <utils/Timers.h>
26 
27 #include <quakedef.h>
28 
29 // Timer utilities
30 
31 #define ENABLE_PMP
32 #define USE_LOG
33 
34 #ifdef ENABLE_PMP
35 
36 static nsecs_t baseTime;
37 static nsecs_t lastTime;
38 static const unsigned int kStartTimeStackSize = 100;
39 static nsecs_t startTimes[kStartTimeStackSize];
40 static unsigned int startTimeStackPointer;
41 
42 static
PMP_Common(const char * fmt,va_list ap,char type)43 void PMP_Common(const char* fmt, va_list ap, char type)
44 {
45 	char buf[1024];
46 	vsnprintf(buf, sizeof(buf), fmt, ap);
47 	va_end(ap);
48 
49 	// Note: Timer acually has less than microsecond resolution, so track time in microseconds:
50 
51 	nsecs_t time = systemTime(SYSTEM_TIME_THREAD) / 1000;
52 	if(baseTime == 0)
53 	{
54 		baseTime = time;
55 	}
56 	time -= baseTime;
57 	switch(type)
58 	{
59 	case '<':
60 		{
61 			if(startTimeStackPointer < kStartTimeStackSize)
62 			{
63 				startTimes[startTimeStackPointer] = time;
64 			}
65 #ifdef USE_LOG
66 			ALOGI("< %lld [%d] %s\n", time, startTimeStackPointer, buf);
67 #else
68 			fprintf(stderr, "Quake < %lld %d %s\n", time, startTimeStackPointer, buf);
69 #endif
70 			startTimeStackPointer++;
71 		}
72 		break;
73 	case '>':
74 		{
75 			nsecs_t elapsed = 0;
76 			if(startTimeStackPointer > 0)
77 			{
78 				--startTimeStackPointer;
79 				if(startTimeStackPointer < kStartTimeStackSize)
80 				{
81 					elapsed = time - startTimes[startTimeStackPointer];
82 				}
83 			}
84 #ifdef USE_LOG
85 			ALOGI("> %lld [%d] %lld %s\n", time, startTimeStackPointer, elapsed, buf);
86 #else
87 			fprintf(stderr, "Quake > %lld [%d] %lld %s\n", time, startTimeStackPointer, elapsed, buf);
88 #endif
89 		}
90 		break;
91 	default:
92 #ifdef USE_LOG
93 		ALOGI("= %lld %lld %s\n", time, time - lastTime, buf);
94 #else
95 		fprintf(stderr, "Quake = %lld %s\n", time, buf);
96 #endif
97 		break;
98 	}
99 	lastTime = time;
100 }
101 
PMP_Begin(const char * fmt,...)102 void PMP_Begin(const char* fmt,...)
103 {
104 	va_list ap;
105 	va_start(ap, fmt);
106 	PMP_Common(fmt, ap, '<');
107 }
108 
PMP_Event(const char * fmt,...)109 void PMP_Event(const char* fmt,...)
110 {
111 	va_list ap;
112 	va_start(ap, fmt);
113 	PMP_Common(fmt, ap, '=');
114 }
115 
PMP_End(const char * fmt,...)116 void PMP_End(const char* fmt,...)
117 {
118 	va_list ap;
119 	va_start(ap, fmt);
120 	PMP_Common(fmt, ap, '>');
121 }
122 
123 #endif // ENABLE_PMP
124