/* * Copyright (C) 2007 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include <stdlib.h> #include <stdio.h> #include <time.h> #include <sched.h> #include <sys/resource.h> #include <EGL/egl.h> #include <GLES/gl.h> #include <GLES/glext.h> long long systemTime() { struct timespec t; t.tv_sec = t.tv_nsec = 0; clock_gettime(CLOCK_MONOTONIC, &t); return (long long)(t.tv_sec)*1000000000LL + t.tv_nsec; } int main(int argc, char** argv) { EGLint s_configAttribs[] = { EGL_RED_SIZE, 5, EGL_GREEN_SIZE, 6, EGL_BLUE_SIZE, 5, EGL_NONE }; EGLint numConfigs = -1; EGLint majorVersion; EGLint minorVersion; EGLConfig config; EGLContext context; EGLSurface surface; EGLint w, h; EGLDisplay dpy; dpy = eglGetDisplay(EGL_DEFAULT_DISPLAY); eglInitialize(dpy, &majorVersion, &minorVersion); eglChooseConfig(dpy, s_configAttribs, &config, 1, &numConfigs); surface = eglCreateWindowSurface(dpy, config, android_createDisplaySurface(), NULL); context = eglCreateContext(dpy, config, NULL, NULL); eglMakeCurrent(dpy, surface, surface, context); eglQuerySurface(dpy, surface, EGL_WIDTH, &w); eglQuerySurface(dpy, surface, EGL_HEIGHT, &h); GLint dim = w<h ? w : h; glBindTexture(GL_TEXTURE_2D, 0); glTexParameterx(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); glTexParameterx(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST); glTexEnvx(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE); glEnable(GL_TEXTURE_2D); glColor4f(1,1,1,1); glDisable(GL_DITHER); glShadeModel(GL_FLAT); long long now, t; int i; char* texels = malloc(512*512*2); memset(texels,0xFF,512*512*2); glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 512, 512, 0, GL_RGB, GL_UNSIGNED_SHORT_5_6_5, texels); char* dst = malloc(320*480*2); memset(dst, 0, 320*480*2); printf("307200 bytes memcpy\n"); for (i=0 ; i<4 ; i++) { now = systemTime(); memcpy(dst, texels, 320*480*2); t = systemTime(); printf("memcpy() time = %llu us\n", (t-now)/1000); fflush(stdout); } free(dst); free(texels); setpriority(PRIO_PROCESS, 0, -20); printf("512x512 unmodified texture, 512x512 blit:\n"); glClear(GL_COLOR_BUFFER_BIT); for (i=0 ; i<4 ; i++) { GLint crop[4] = { 0, 512, 512, -512 }; glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_CROP_RECT_OES, crop); now = systemTime(); glDrawTexiOES(0, 0, 0, 512, 512); glFinish(); t = systemTime(); printf("glFinish() time = %llu us\n", (t-now)/1000); fflush(stdout); eglSwapBuffers(dpy, surface); } printf("512x512 unmodified texture, 1x1 blit:\n"); glClear(GL_COLOR_BUFFER_BIT); for (i=0 ; i<4 ; i++) { GLint crop[4] = { 0, 1, 1, -1 }; glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_CROP_RECT_OES, crop); now = systemTime(); glDrawTexiOES(0, 0, 0, 1, 1); glFinish(); t = systemTime(); printf("glFinish() time = %llu us\n", (t-now)/1000); fflush(stdout); eglSwapBuffers(dpy, surface); } printf("512x512 unmodified texture, 512x512 blit (x2):\n"); glClear(GL_COLOR_BUFFER_BIT); for (i=0 ; i<4 ; i++) { GLint crop[4] = { 0, 512, 512, -512 }; glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_CROP_RECT_OES, crop); now = systemTime(); glDrawTexiOES(0, 0, 0, 512, 512); glDrawTexiOES(0, 0, 0, 512, 512); glFinish(); t = systemTime(); printf("glFinish() time = %llu us\n", (t-now)/1000); fflush(stdout); eglSwapBuffers(dpy, surface); } printf("512x512 unmodified texture, 1x1 blit (x2):\n"); glClear(GL_COLOR_BUFFER_BIT); for (i=0 ; i<4 ; i++) { GLint crop[4] = { 0, 1, 1, -1 }; glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_CROP_RECT_OES, crop); now = systemTime(); glDrawTexiOES(0, 0, 0, 1, 1); glDrawTexiOES(0, 0, 0, 1, 1); glFinish(); t = systemTime(); printf("glFinish() time = %llu us\n", (t-now)/1000); fflush(stdout); eglSwapBuffers(dpy, surface); } printf("512x512 (1x1 texel MODIFIED texture), 512x512 blit:\n"); glClear(GL_COLOR_BUFFER_BIT); for (i=0 ; i<4 ; i++) { uint16_t green = 0x7E0; GLint crop[4] = { 0, 512, 512, -512 }; glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_CROP_RECT_OES, crop); glTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, 1, 1, GL_RGB, GL_UNSIGNED_SHORT_5_6_5, &green); now = systemTime(); glDrawTexiOES(0, 0, 0, 512, 512); glFinish(); t = systemTime(); printf("glFinish() time = %llu us\n", (t-now)/1000); fflush(stdout); eglSwapBuffers(dpy, surface); } int16_t texel = 0xF800; glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, 1, 1, 0, GL_RGB, GL_UNSIGNED_SHORT_5_6_5, &texel); printf("1x1 unmodified texture, 1x1 blit:\n"); glClear(GL_COLOR_BUFFER_BIT); for (i=0 ; i<4 ; i++) { GLint crop[4] = { 0, 1, 1, -1 }; glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_CROP_RECT_OES, crop); now = systemTime(); glDrawTexiOES(0, 0, 0, 1, 1); glFinish(); t = systemTime(); printf("glFinish() time = %llu us\n", (t-now)/1000); eglSwapBuffers(dpy, surface); } printf("1x1 unmodified texture, 512x512 blit:\n"); glClear(GL_COLOR_BUFFER_BIT); for (i=0 ; i<4 ; i++) { GLint crop[4] = { 0, 1, 1, -1 }; glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_CROP_RECT_OES, crop); now = systemTime(); glDrawTexiOES(0, 0, 0, 512, 512); glFinish(); t = systemTime(); printf("glFinish() time = %llu us\n", (t-now)/1000); fflush(stdout); eglSwapBuffers(dpy, surface); } printf("1x1 (1x1 texel MODIFIED texture), 512x512 blit:\n"); glClear(GL_COLOR_BUFFER_BIT); for (i=0 ; i<4 ; i++) { uint16_t green = 0x7E0; GLint crop[4] = { 0, 1, 1, -1 }; glTexParameteriv(GL_TEXTURE_2D, GL_TEXTURE_CROP_RECT_OES, crop); glTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, 1, 1, GL_RGB, GL_UNSIGNED_SHORT_5_6_5, &green); now = systemTime(); glDrawTexiOES(0, 0, 0, 1, 1); glFinish(); t = systemTime(); printf("glFinish() time = %llu us\n", (t-now)/1000); fflush(stdout); eglSwapBuffers(dpy, surface); } return 0; }