diff options
author | Doug Zongker <dougz@android.com> | 2012-07-20 22:35:27 -0700 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2012-07-20 22:35:27 -0700 |
commit | aade2e590e17b0f47dbf554f7df5824ba4096212 (patch) | |
tree | 298891653e354d3360b3e4bbb756e90e631dd983 | |
parent | ee57854b7e2836240a14b955f8b6622b4dca61b6 (diff) | |
parent | dd6cd4fcc1b22df7f55e1ab3e54589939dc54179 (diff) | |
download | bootable_recovery-aade2e590e17b0f47dbf554f7df5824ba4096212.zip bootable_recovery-aade2e590e17b0f47dbf554f7df5824ba4096212.tar.gz bootable_recovery-aade2e590e17b0f47dbf554f7df5824ba4096212.tar.bz2 |
am dd6cd4fc: Merge "graphics: add support for "single buffering""
* commit 'dd6cd4fcc1b22df7f55e1ab3e54589939dc54179':
graphics: add support for "single buffering"
-rw-r--r-- | minui/graphics.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/minui/graphics.c b/minui/graphics.c index de1cfdf..296e2e0 100644 --- a/minui/graphics.c +++ b/minui/graphics.c @@ -57,6 +57,7 @@ static GGLSurface gr_font_texture; static GGLSurface gr_framebuffer[2]; static GGLSurface gr_mem_surface; static unsigned gr_active_fb = 0; +static unsigned double_buffering = 0; static int gr_fb_fd = -1; static int gr_vt_fd = -1; @@ -139,6 +140,12 @@ static int get_framebuffer(GGLSurface *fb) fb++; + /* check if we can use double buffering */ + if (vi.yres * fi.line_length * 2 > fi.smem_len) + return fd; + + double_buffering = 1; + fb->version = sizeof(*fb); fb->width = vi.xres; fb->height = vi.yres; @@ -161,7 +168,7 @@ static void get_memory_surface(GGLSurface* ms) { static void set_active_framebuffer(unsigned n) { - if (n > 1) return; + if (n > 1 || !double_buffering) return; vi.yres_virtual = vi.yres * PIXEL_SIZE; vi.yoffset = n * vi.yres; vi.bits_per_pixel = PIXEL_SIZE * 8; @@ -175,7 +182,8 @@ void gr_flip(void) GGLContext *gl = gr_context; /* swap front and back buffers */ - gr_active_fb = (gr_active_fb + 1) & 1; + if (double_buffering) + gr_active_fb = (gr_active_fb + 1) & 1; /* copy data from the in-memory surface to the buffer we're about * to make active. */ |