diff options
-rw-r--r-- | libvo/vo_svga.c | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/libvo/vo_svga.c b/libvo/vo_svga.c index a245677679..8677b0e088 100644 --- a/libvo/vo_svga.c +++ b/libvo/vo_svga.c @@ -285,14 +285,48 @@ static uint32_t init(uint32_t width, uint32_t height, uint32_t d_width, list = list->next; } + if(vo_subdevice) { + int vm; + vm=vga_getmodenumber(vo_subdevice); + list=modelist; + while(list) { + if(list->modenum == vm) { + buf_w = list->modeinfo.width; + buf_h = list->modeinfo.height; + res_widescr = (((buf_w*1.0)/buf_h) > (4.0/3)) ? 1 : 0; + switch(list->modeinfo.colors) { + case 32768: + bpp=16; + bpp_conv=1; + break; + case 65536: + bpp=16; + bpp_conv=0; + break; + case (1<<24): + if(list->modeinfo.bytesperpixel == 3) { + bpp=32; + bpp_conv=1; + } else { + bpp=32; + bpp_conv=0; + } + break; + } + vid_mode=vm; + list=NULL; + } else list=list->next; + } + } + if (verbose) printf("vo_svga: vid_mode: %d\n",vid_mode); - vga_setlinearaddressing(); if (vga_setmode(vid_mode) == -1) { printf("vo_svga: vga_setmode(%d) failed.\n",vid_mode); uninit(); return(1); // error } + vga_setlinearaddressing(); if (gl_setcontextvga(vid_mode)) { printf("vo_svga: gl_setcontextvga(%d) failed.\n",vid_mode); uninit(); |