X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=dosdemo;a=blobdiff_plain;f=src%2Fdos%2Fmain.c;h=aed12e98feaec4fe8b245b839ad12697828c8abb;hp=6d83027d039bdcc22650b88cfab7e999b177db4a;hb=772dfe62feafd0583e52326c7419ef01e04cac60;hpb=f8bae6c14df76c506af4474cbf29402d2bfa8209 diff --git a/src/dos/main.c b/src/dos/main.c index 6d83027..aed12e9 100644 --- a/src/dos/main.c +++ b/src/dos/main.c @@ -31,7 +31,7 @@ static quat_t rot = {0, 0, 0, 1}; int main(int argc, char **argv) { - fbsize = fb_width * fb_height * fb_bpp / CHAR_BIT; + fbsize = fb_width * fb_height * fb_bpp / 8; init_logger("demo.log"); @@ -46,12 +46,14 @@ int main(int argc, char **argv) set_mouse(fb_width / 2, fb_height / 2); } - if(!(fb_pixels = malloc(fbsize))) { + /* allocate a couple extra rows as a guard band, until we fucking fix the rasterizer */ + if(!(fb_pixels = malloc(fbsize + (fb_width * fb_bpp / 8) * 2))) { fprintf(stderr, "failed to allocate backbuffer\n"); return 1; } + fb_pixels += fb_width; - if(!(vmem = set_video_mode(fb_width, fb_height, fb_bpp))) { + if(!(vmem = set_video_mode(fb_width, fb_height, fb_bpp, 1))) { return 1; }