1 // OpenGL ES 2.0 code
2
3 #include <nativehelper/jni.h>
4 #define LOG_TAG "GLPerf gl_code.cpp"
5 #include <utils/Log.h>
6
7 #include <EGL/egl.h>
8 #include <GLES2/gl2.h>
9 #include <GLES2/gl2ext.h>
10 #include <utils/Timers.h>
11
12 #include <stdio.h>
13 #include <stdlib.h>
14 #include <math.h>
15
16 #include "../../gl_perf/fill_common.cpp"
17
18
19 //////////////////////////
20
21 // Width and height of the screen
22
23 uint32_t w;
24 uint32_t h;
25
26 // The stateClock starts at zero and increments by 1 every time we draw a frame. It is used to control which phase of the test we are in.
27
28 int stateClock;
29 bool done;
30
31 // Saves the parameters of the test (so we can print them out when we finish the timing.)
32
33
34 int pgm;
35
ptSwap()36 void ptSwap() {
37 }
38
doTest()39 void doTest() {
40 uint32_t testNum = stateClock >> 2;
41 int texSize = ((stateClock >> 1) & 0x1) + 1;
42
43 if (testNum >= gFragmentTestCount) {
44 ALOGI("done\n");
45 if (fOut) {
46 fclose(fOut);
47 fOut = NULL;
48 }
49 done = true;
50 return;
51 }
52
53 // ALOGI("doTest %d %d %d\n", texCount, extraMath, testSubState);
54
55 // for (uint32_t num = 0; num < gFragmentTestCount; num++) {
56 doSingleTest(testNum, texSize);
57 }
58
59 extern "C" {
60 JNIEXPORT void JNICALL Java_com_android_glperf_GLPerfLib_init(JNIEnv * env, jobject obj, jint width, jint height);
61 JNIEXPORT void JNICALL Java_com_android_glperf_GLPerfLib_step(JNIEnv * env, jobject obj);
62 };
63
Java_com_android_glperf_GLPerfLib_init(JNIEnv * env,jobject obj,jint width,jint height)64 JNIEXPORT void JNICALL Java_com_android_glperf_GLPerfLib_init(JNIEnv * env, jobject obj, jint width, jint height)
65 {
66 gWidth = width;
67 gHeight = height;
68 if (!done) {
69 stateClock = 0;
70 done = false;
71 setupVA();
72 genTextures();
73 const char* fileName = "/sdcard/glperf.csv";
74 if (fOut != NULL) {
75 ALOGI("Closing partially written output.n");
76 fclose(fOut);
77 fOut = NULL;
78 }
79 ALOGI("Writing to: %s\n",fileName);
80 fOut = fopen(fileName, "w");
81 if (fOut == NULL) {
82 ALOGE("Could not open: %s\n", fileName);
83 }
84
85 ALOGI("\nvarColor, texCount, modulate, extraMath, texSize, blend, Mpps, DC60\n");
86 if (fOut) fprintf(fOut,"varColor, texCount, modulate, extraMath, texSize, blend, Mpps, DC60\r\n");
87 }
88 }
89
Java_com_android_glperf_GLPerfLib_step(JNIEnv * env,jobject obj)90 JNIEXPORT void JNICALL Java_com_android_glperf_GLPerfLib_step(JNIEnv * env, jobject obj)
91 {
92 if (! done) {
93 if (stateClock > 0 && ((stateClock & 1) == 0)) {
94 //endTimer(100);
95 }
96 doTest();
97 stateClock++;
98 } else {
99 glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT);
100 }
101 }
102