X-Git-Url: http://git.mutantstargoat.com/user/nuclear/?p=bootcensus;a=blobdiff_plain;f=src%2Fvideo.c;fp=src%2Fvideo.c;h=ba89bad92b0649571e2284b876f96535bd4d9bde;hp=d926107764fe2213cbd8939e2401bf83c0ded7b7;hb=81c11bdd80190ec319a82b0402173cfb65fcbf72;hpb=7dcd5071e600f8cf48174d1fddb3dba57ec9476d diff --git a/src/video.c b/src/video.c index d926107..ba89bad 100644 --- a/src/video.c +++ b/src/video.c @@ -103,10 +103,9 @@ void *set_video_mode(int mode) return (void*)mode_info->fb_addr; } -int find_video_mode(int xsz, int ysz, int bpp) +int find_video_mode_idx(int xsz, int ysz, int bpp) { - int i; - uint16_t best = 0; + int i, best = -1, best_bpp = 0; struct vbe_mode_info *inf; if(init_once() == -1) return -1; @@ -116,12 +115,13 @@ int find_video_mode(int xsz, int ysz, int bpp) if(!inf || inf->xres != xsz || inf->yres != ysz) { continue; } - if(SAME_BPP(inf->bpp, bpp)) { - best = modes[i]; + if((bpp <= 0 && inf->bpp > best_bpp) || SAME_BPP(inf->bpp, bpp)) { + best = i; + best_bpp = inf->bpp; } } - if(!best) { + if(best == -1) { printf("Requested video mode (%dx%d %dbpp) is unavailable\n", xsz, ysz, bpp); return -1; } @@ -197,3 +197,15 @@ unsigned int color_mask(int nbits, int pos) static unsigned int maskbits[] = {0, 1, 3, 7, 0xf, 0x1f, 0x3f, 0x7f, 0xff}; return maskbits[nbits] << pos; } + +const char *get_video_vendor(void) +{ + if(init_once() == -1) return 0; + return (char*)VBEPTR(vbe_info->oem_vendor_name_ptr); +} + +int get_video_mem_size(void) +{ + if(init_once() == -1) return 0; + return vbe_info->total_mem << 6; +}