X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=dosdemo;a=blobdiff_plain;f=src%2Fdos%2Fmain.c;h=6d83027d039bdcc22650b88cfab7e999b177db4a;hp=0f8abf51245c62ddfe07738054795fcae9abb0f0;hb=7deef4d5a20da09044bf7311c6ee274090cde5e6;hpb=b82bab85314bbc57d1c542d4d6687de0cd75c375 diff --git a/src/dos/main.c b/src/dos/main.c index 0f8abf5..6d83027 100644 --- a/src/dos/main.c +++ b/src/dos/main.c @@ -51,15 +51,9 @@ int main(int argc, char **argv) return 1; } - if(!(vmem_back = set_video_mode(fb_width, fb_height, fb_bpp))) { + if(!(vmem = set_video_mode(fb_width, fb_height, fb_bpp))) { return 1; } - if(!(vmem_front = page_flip(FLIP_NOW))) { - fprintf(stderr, "page flipping not supported. falling back to double buffering\n"); - vmem_front = vmem_back; - } else { - assert(vmem_back != vmem_front); - } if(demo_init(argc, argv) == -1) { set_text_mode(); @@ -119,32 +113,16 @@ void demo_quit(void) void swap_buffers(void *pixels) { - if(pixels) { - /* just memcpy to the front buffer */ - if(opt.vsync) { - wait_vsync(); - } - drawFps(pixels); - memcpy(vmem_front, pixels, fbsize); - - } else { - /* attempt page flipping */ - void *next; - - drawFps(vmem_back); - if((next = page_flip(opt.vsync ? FLIP_VBLANK : FLIP_NOW))) { - assert(next == vmem_back); - vmem_back = vmem_front; - vmem_front = next; - } else { - /* failed to page flip, assume we drew in the front buffer then - * and just wait for vsync if necessary - */ - if(opt.vsync) { - wait_vsync(); - } - } + if(!pixels) { + pixels = fb_pixels; + } + + /* just memcpy to the front buffer */ + if(opt.vsync) { + wait_vsync(); } + drawFps(pixels); + memcpy(vmem, pixels, fbsize); }