CVS: main/libvo vo_fbdev.c,1.18,1.19
Update of /cvsroot/mplayer/main/libvo In directory usw-pr-cvs1:/tmp/cvs-serv10505 Modified Files: vo_fbdev.c Log Message: cleanup Index: vo_fbdev.c =================================================================== RCS file: /cvsroot/mplayer/main/libvo/vo_fbdev.c,v retrieving revision 1.18 retrieving revision 1.19 diff -C2 -r1.18 -r1.19 *** vo_fbdev.c 2001/04/11 21:54:34 1.18 --- vo_fbdev.c 2001/04/12 20:38:45 1.19 *************** *** 39,42 **** --- 39,44 ---- }; + extern int verbose; + /****************************** * fb.modes parser * *************** *** 353,357 **** static int fb_bpp; // 32: 32 24: 24 16: 16 15: 15 static int fb_screen_width; - static int fb_orig_depth; char *fb_dev_name = NULL; --- 355,358 ---- *************** *** 440,443 **** --- 441,484 ---- } + static void set_rgb_fields(struct fb_var_screeninfo *p, int depth) + { + switch (depth) { + case 32: + case 24: + p->red.offset = 16; + p->red.length = 8; + p->red.msb_right = 0; + p->green.offset = 8; + p->green.length = 8; + p->green.msb_right = 0; + p->blue.offset = 0; + p->blue.length = 8; + p->blue.msb_right = 0; + break; + case 16: + p->red.offset = 11; + p->red.length = 5; + p->red.msb_right = 0; + p->green.offset = 5; + p->green.length = 6; + p->green.msb_right = 0; + p->blue.offset = 0; + p->blue.length = 5; + p->blue.msb_right = 0; + break; + case 15: + p->red.offset = 10; + p->red.length = 5; + p->red.msb_right = 0; + p->green.offset = 5; + p->green.length = 5; + p->green.msb_right = 0; + p->blue.offset = 0; + p->blue.length = 5; + p->blue.msb_right = 0; + break; + } + } + static int fb_init(void) { *************** *** 449,462 **** return 1; if (!(fb_mode = find_mode_by_name(fb_mode_name))) { ! printf("fb_init: can't find requested video mode\n"); return 1; } fb_switch_mode = 1; } else if (fb_mode_depth) { ! printf("fb_init: Do _not_ use the 'fbdepth' parameter! " "this parameter will be removed\n"); if (fb_mode_depth != 15 && fb_mode_depth != 16 && fb_mode_depth != 24 && fb_mode_depth != 32) { ! printf("fb_init: can't switch to %d bpp\n", fb_mode_depth); return 1; } --- 490,503 ---- return 1; if (!(fb_mode = find_mode_by_name(fb_mode_name))) { ! printf("fb: can't find requested video mode\n"); return 1; } fb_switch_mode = 1; } else if (fb_mode_depth) { ! printf("fb: Do _not_ use the 'fbdepth' parameter! " "this parameter will be removed\n"); if (fb_mode_depth != 15 && fb_mode_depth != 16 && fb_mode_depth != 24 && fb_mode_depth != 32) { ! printf("fb: can't switch to %d bpp\n", fb_mode_depth); return 1; } *************** *** 465,477 **** if (!fb_dev_name && !(fb_dev_name = getenv("FRAMEBUFFER"))) fb_dev_name = "/dev/fb0"; ! printf("fb_init: using %s\n", fb_dev_name); if ((fb_dev_fd = open(fb_dev_name, O_RDWR)) == -1) { ! printf("fb_init: Can't open %s: %s\n", fb_dev_name, strerror(errno)); goto err_out; } if (ioctl(fb_dev_fd, FBIOGET_VSCREENINFO, &fb_vinfo)) { ! printf("fb_init: Can't get VSCREENINFO: %s\n", strerror(errno)); goto err_out_fd; } --- 506,519 ---- if (!fb_dev_name && !(fb_dev_name = getenv("FRAMEBUFFER"))) fb_dev_name = "/dev/fb0"; ! if (verbose > 0) ! printf("fb: using %s\n", fb_dev_name); if ((fb_dev_fd = open(fb_dev_name, O_RDWR)) == -1) { ! printf("fb: Can't open %s: %s\n", fb_dev_name, strerror(errno)); goto err_out; } if (ioctl(fb_dev_fd, FBIOGET_VSCREENINFO, &fb_vinfo)) { ! printf("fb: Can't get VSCREENINFO: %s\n", strerror(errno)); goto err_out_fd; } *************** *** 484,520 **** fb_vinfo.yres_virtual = fb_mode->vyres; fb_vinfo.bits_per_pixel = fb_mode->depth; ! switch (fb_mode->depth) { ! case 32: ! case 24: ! fb_vinfo.red.offset = 16; ! fb_vinfo.red.length = 8; ! fb_vinfo.red.msb_right = 0; ! fb_vinfo.green.offset = 8; ! fb_vinfo.green.length = 8; ! fb_vinfo.green.msb_right = 0; ! fb_vinfo.blue.offset = 0; ! fb_vinfo.blue.length = 8; ! fb_vinfo.blue.msb_right = 0; ! case 16: ! fb_vinfo.red.offset = 11; ! fb_vinfo.red.length = 5; ! fb_vinfo.red.msb_right = 0; ! fb_vinfo.green.offset = 5; ! fb_vinfo.green.length = 6; ! fb_vinfo.green.msb_right = 0; ! fb_vinfo.blue.offset = 0; ! fb_vinfo.blue.length = 5; ! fb_vinfo.blue.msb_right = 0; ! case 15: ! fb_vinfo.red.offset = 10; ! fb_vinfo.red.length = 5; ! fb_vinfo.red.msb_right = 0; ! fb_vinfo.green.offset = 5; ! fb_vinfo.green.length = 5; ! fb_vinfo.green.msb_right = 0; ! fb_vinfo.blue.offset = 0; ! fb_vinfo.blue.length = 5; ! fb_vinfo.blue.msb_right = 0; ! } fb_vinfo.pixclock = fb_mode->pixclock; fb_vinfo.left_margin = fb_mode->left; --- 526,530 ---- fb_vinfo.yres_virtual = fb_mode->vyres; fb_vinfo.bits_per_pixel = fb_mode->depth; ! set_rgb_fields(&fb_vinfo, fb_mode->depth); fb_vinfo.pixclock = fb_mode->pixclock; fb_vinfo.left_margin = fb_mode->left; *************** *** 527,565 **** fb_vinfo.vmode = fb_mode->vmode; } else if (fb_mode_depth) { - fb_orig_depth = fb_vinfo.bits_per_pixel; fb_vinfo.bits_per_pixel = fb_mode_depth; ! switch (fb_mode_depth) { ! case 32: ! case 24: ! fb_vinfo.red.offset = 16; ! fb_vinfo.red.length = 8; ! fb_vinfo.red.msb_right = 0; ! fb_vinfo.green.offset = 8; ! fb_vinfo.green.length = 8; ! fb_vinfo.green.msb_right = 0; ! fb_vinfo.blue.offset = 0; ! fb_vinfo.blue.length = 8; ! fb_vinfo.blue.msb_right = 0; ! case 16: ! fb_vinfo.red.offset = 11; ! fb_vinfo.red.length = 5; ! fb_vinfo.red.msb_right = 0; ! fb_vinfo.green.offset = 5; ! fb_vinfo.green.length = 6; ! fb_vinfo.green.msb_right = 0; ! fb_vinfo.blue.offset = 0; ! fb_vinfo.blue.length = 5; ! fb_vinfo.blue.msb_right = 0; ! case 15: ! fb_vinfo.red.offset = 10; ! fb_vinfo.red.length = 5; ! fb_vinfo.red.msb_right = 0; ! fb_vinfo.green.offset = 5; ! fb_vinfo.green.length = 5; ! fb_vinfo.green.msb_right = 0; ! fb_vinfo.blue.offset = 0; ! fb_vinfo.blue.length = 5; ! fb_vinfo.blue.msb_right = 0; ! } } fb_vinfo.xres_virtual = fb_vinfo.xres; --- 537,542 ---- fb_vinfo.vmode = fb_mode->vmode; } else if (fb_mode_depth) { fb_vinfo.bits_per_pixel = fb_mode_depth; ! set_rgb_fields(&fb_vinfo, fb_mode_depth); } fb_vinfo.xres_virtual = fb_vinfo.xres; *************** *** 567,576 **** if (ioctl(fb_dev_fd, FBIOPUT_VSCREENINFO, &fb_vinfo)) { ! printf("fb_init: Can't put VSCREENINFO: %s\n", strerror(errno)); goto err_out_fd; } if (ioctl(fb_dev_fd, FBIOGET_FSCREENINFO, &fb_finfo)) { ! printf("fb_init: Can't get VSCREENINFO: %s\n", strerror(errno)); goto err_out_fd; return 1; --- 544,553 ---- if (ioctl(fb_dev_fd, FBIOPUT_VSCREENINFO, &fb_vinfo)) { ! printf("fb: Can't put VSCREENINFO: %s\n", strerror(errno)); goto err_out_fd; } if (ioctl(fb_dev_fd, FBIOGET_FSCREENINFO, &fb_finfo)) { ! printf("fb: Can't get VSCREENINFO: %s\n", strerror(errno)); goto err_out_fd; return 1; *************** *** 578,595 **** switch (fb_finfo.type) { case FB_TYPE_VGA_PLANES: ! printf("fb_init: FB_TYPE_VGA_PLANES not supported.\n"); goto err_out_fd; break; case FB_TYPE_PLANES: ! printf("fb_init: FB_TYPE_PLANES not supported.\n"); goto err_out_fd; break; case FB_TYPE_INTERLEAVED_PLANES: ! printf("fb_init: FB_TYPE_INTERLEAVED_PLANES not supported.\n"); goto err_out_fd; break; #ifdef FB_TYPE_TEXT case FB_TYPE_TEXT: ! printf("fb_init: FB_TYPE_TEXT not supported.\n"); goto err_out_fd; break; --- 555,572 ---- switch (fb_finfo.type) { case FB_TYPE_VGA_PLANES: ! printf("fb: FB_TYPE_VGA_PLANES not supported.\n"); goto err_out_fd; break; case FB_TYPE_PLANES: ! printf("fb: FB_TYPE_PLANES not supported.\n"); goto err_out_fd; break; case FB_TYPE_INTERLEAVED_PLANES: ! printf("fb: FB_TYPE_INTERLEAVED_PLANES not supported.\n"); goto err_out_fd; break; #ifdef FB_TYPE_TEXT case FB_TYPE_TEXT: ! printf("fb: FB_TYPE_TEXT not supported.\n"); goto err_out_fd; break; *************** *** 597,610 **** case FB_TYPE_PACKED_PIXELS: /* OK */ ! printf("fb_init: FB_TYPE_PACKED_PIXELS: OK\n"); break; default: ! printf("fb_init: unknown FB_TYPE: %d\n", fb_finfo.type); goto err_out_fd; } ! if (fb_finfo.visual == FB_VISUAL_DIRECTCOLOR) { ! printf("fb_init: creating cmap for directcolor\n"); if (ioctl(fb_dev_fd, FBIOGETCMAP, fb_oldcmap)) { ! printf("fb_init: can't get cmap: %s\n", strerror(errno)); goto err_out_fd; --- 574,592 ---- case FB_TYPE_PACKED_PIXELS: /* OK */ ! if (verbose > 0) ! printf("fb: FB_TYPE_PACKED_PIXELS: OK\n"); break; default: ! printf("fb: unknown FB_TYPE: %d\n", fb_finfo.type); goto err_out_fd; } ! switch (fb_finfo.visual) { ! case FB_VISUAL_TRUECOLOR: ! break; ! case FB_VISUAL_DIRECTCOLOR: ! if (verbose > 0) ! printf("fb: creating cmap for directcolor\n"); if (ioctl(fb_dev_fd, FBIOGETCMAP, fb_oldcmap)) { ! printf("fb: can't get cmap: %s\n", strerror(errno)); goto err_out_fd; *************** *** 613,617 **** goto err_out_fd; if (ioctl(fb_dev_fd, FBIOPUTCMAP, cmap)) { ! printf("fb_init: can't put cmap: %s\n", strerror(errno)); goto err_out_fd; --- 595,599 ---- goto err_out_fd; if (ioctl(fb_dev_fd, FBIOPUTCMAP, cmap)) { ! printf("fb: can't put cmap: %s\n", strerror(errno)); goto err_out_fd; *************** *** 621,626 **** free(cmap->blue); free(cmap); ! } else if (fb_finfo.visual != FB_VISUAL_TRUECOLOR) { ! printf("fb_init: visual: %d not yet supported\n", fb_finfo.visual); goto err_out_fd; --- 603,609 ---- free(cmap->blue); free(cmap); ! break; ! default: ! printf("fb: visual: %d not yet supported\n", fb_finfo.visual); goto err_out_fd; *************** *** 635,655 **** if ((frame_buffer = (uint8_t *) mmap(0, fb_size, PROT_READ | PROT_WRITE, MAP_SHARED, fb_dev_fd, 0)) == (uint8_t *) -1) { ! printf("fb_init: Can't mmap %s: %s\n", fb_dev_name, strerror(errno)); goto err_out_fd; } ! printf("fb_init: framebuffer @ %p\n", frame_buffer); ! printf("fb_init: framebuffer size: %d bytes\n", fb_size); ! printf("fb_init: bpp: %d\n", fb_bpp); ! printf("fb_init: real bpp: %d\n", fb_real_bpp); ! printf("fb_init: pixel size: %d bytes\n", fb_pixel_size); ! printf("fb_init: pixel per line: %d\n", fb_screen_width / fb_pixel_size); ! printf("fb_init: visual: %d\n", fb_finfo.visual); ! printf("fb_init: red: %d %d %d\n", fb_vinfo.red.offset, ! fb_vinfo.red.length, fb_vinfo.red.msb_right); ! printf("fb_init: green: %d %d %d\n", fb_vinfo.green.offset, ! fb_vinfo.green.length, fb_vinfo.green.msb_right); ! printf("fb_init: blue: %d %d %d\n", fb_vinfo.blue.offset, ! fb_vinfo.blue.length, fb_vinfo.blue.msb_right); fb_init_done = 1; --- 618,681 ---- if ((frame_buffer = (uint8_t *) mmap(0, fb_size, PROT_READ | PROT_WRITE, MAP_SHARED, fb_dev_fd, 0)) == (uint8_t *) -1) { ! printf("fb: Can't mmap %s: %s\n", fb_dev_name, strerror(errno)); goto err_out_fd; } ! if (verbose > 0 && verbose < 4) ! printf("fb: use verbose level >= 4 to get some info (you will get _lots_ of info)\n"); ! if (verbose >= 4) { ! printf("fb: fix info:\n"); ! printf("fb: id: %.16s\n", fb_finfo.id); ! printf("fb: smem_start: %p\n", fb_finfo.smem_start); ! printf("fb: framebuffer size: %d bytes\n", fb_size); ! printf("fb: type: %lu\n", fb_finfo.type); ! printf("fb: type_aux: %lu\n", fb_finfo.type_aux); ! printf("fb: visual: %lu\n", fb_finfo.visual); ! printf("fb: xpanstep: %u\n", fb_finfo.xpanstep); ! printf("fb: ypanstep: %u\n", fb_finfo.ypanstep); ! printf("fb: ywrapstep: %u\n", fb_finfo.ywrapstep); ! printf("fb: line_length: %lu bytes\n", fb_finfo.line_length); ! printf("fb: mmio_start: %p\n", fb_finfo.mmio_start); ! printf("fb: mmio_len: %ul bytes\n", fb_finfo.mmio_len); ! printf("fb: accel: %ul\n", fb_finfo.accel); ! printf("fb: var info:\n"); ! printf("fb: xres: %ul\n", fb_vinfo.xres); ! printf("fb: yres: %ul\n", fb_vinfo.yres); ! printf("fb: xres_virtual: %ul\n", fb_vinfo.xres_virtual); ! printf("fb: yres_virtual: %ul\n", fb_vinfo.yres_virtual); ! printf("fb: xoffset: %ul\n", fb_vinfo.xoffset); ! printf("fb: yoffset: %ul\n", fb_vinfo.yoffset); ! printf("fb: bits_per_pixel: %ul\n", fb_vinfo.bits_per_pixel); ! printf("fb: grayscale: %ul\n", fb_vinfo.grayscale); ! printf("fb: red: %lu %lu %lu\n", fb_vinfo.red.offset, ! fb_vinfo.red.length, fb_vinfo.red.msb_right); ! printf("fb: green: %lu %lu %lu\n", fb_vinfo.green.offset, ! fb_vinfo.green.length, fb_vinfo.green.msb_right); ! printf("fb: blue: %lu %lu %lu\n", fb_vinfo.blue.offset, ! fb_vinfo.blue.length, fb_vinfo.blue.msb_right); ! printf("fb: transp: %lu %lu %lu\n", fb_vinfo.transp.offset, ! fb_vinfo.transp.length, fb_vinfo.transp.msb_right); ! printf("fb: nonstd: %ul\n", fb_vinfo.nonstd); ! printf("fb: activate: %ul\n", fb_vinfo.activate); ! printf("fb: height: %ul\n", fb_vinfo.height); ! printf("fb: width: %ul\n", fb_vinfo.width); ! printf("fb: accel_flags: %ul\n", fb_vinfo.accel_flags); ! printf("fb: timing:\n"); ! printf("fb: pixclock: %ul\n", fb_vinfo.pixclock); ! printf("fb: left_margin: %ul\n", fb_vinfo.left_margin); ! printf("fb: right_margin: %ul\n", fb_vinfo.right_margin); ! printf("fb: upper_margin: %ul\n", fb_vinfo.upper_margin); ! printf("fb: lower_margin: %ul\n", fb_vinfo.lower_margin); ! printf("fb: hsync_len: %ul\n", fb_vinfo.hsync_len); ! printf("fb: vsync_len: %ul\n", fb_vinfo.vsync_len); ! printf("fb: sync: %ul\n", fb_vinfo.sync); ! printf("fb: vmode: %ul\n", fb_vinfo.vmode); ! printf("fb: other:\n"); ! printf("fb: frame_buffer @ %p\n", frame_buffer); ! printf("fb: fb_bpp: %d\n", fb_bpp); ! printf("fb: fb_real_bpp: %d\n", fb_real_bpp); ! printf("fb: fb_pixel_size: %d bytes\n", fb_pixel_size); ! printf("fb: pixel per line: %d\n", fb_screen_width / fb_pixel_size); ! } fb_init_done = 1; *************** *** 736,759 **** break; } - #if 0 - int x, y; - uint8_t *dst; - - // if (pixel_format == IMGFMT_YV12) { - for (y = 0; y < h; y++){ - dst = next_frame + (in_width * (y0 + y) + x0) * fb_pixel_size; - for (x = 0; x < w; x++) { - if (srca[x]) { - dst[0]=((dst[0]*srca[x])>>8)+src[x]; - dst[1]=((dst[1]*srca[x])>>8)+src[x]; - dst[2]=((dst[2]*srca[x])>>8)+src[x]; - } - dst += fb_pixel_size; - } - src += stride; - srca += stride; - } - // } - #endif } --- 762,765 ---- *************** *** 824,876 **** static void uninit(void) { ! printf("vo_fbdev: uninit\n"); if (fb_oldcmap) { if (ioctl(fb_dev_fd, FBIOPUTCMAP, fb_oldcmap)) ! printf("vo_fbdev: Can't restore original cmap\n"); fb_oldcmap = NULL; - } - if (fb_switch_mode) - fb_vinfo = fb_orig_vinfo; - else if (fb_mode_depth) { - fb_vinfo.bits_per_pixel = fb_orig_depth; - switch (fb_mode_depth) { - case 32: - case 24: - fb_vinfo.red.offset = 16; - fb_vinfo.red.length = 8; - fb_vinfo.red.msb_right = 0; - fb_vinfo.green.offset = 8; - fb_vinfo.green.length = 8; - fb_vinfo.green.msb_right = 0; - fb_vinfo.blue.offset = 0; - fb_vinfo.blue.length = 8; - fb_vinfo.blue.msb_right = 0; - case 16: - fb_vinfo.red.offset = 11; - fb_vinfo.red.length = 5; - fb_vinfo.red.msb_right = 0; - fb_vinfo.green.offset = 5; - fb_vinfo.green.length = 6; - fb_vinfo.green.msb_right = 0; - fb_vinfo.blue.offset = 0; - fb_vinfo.blue.length = 5; - fb_vinfo.blue.msb_right = 0; - case 15: - fb_vinfo.red.offset = 10; - fb_vinfo.red.length = 5; - fb_vinfo.red.msb_right = 0; - fb_vinfo.green.offset = 5; - fb_vinfo.green.length = 5; - fb_vinfo.green.msb_right = 0; - fb_vinfo.blue.offset = 0; - fb_vinfo.blue.length = 5; - fb_vinfo.blue.msb_right = 0; - } - } else { - fb_vinfo.xres_virtual = fb_orig_vinfo.xres_virtual; - fb_vinfo.yres_virtual = fb_orig_vinfo.yres_virtual; } ! if (ioctl(fb_dev_fd, FBIOPUT_VSCREENINFO, &fb_vinfo)) ! printf("vo_fbdev: Can't set virtual screensize to original value: %s\n", strerror(errno)); close(fb_dev_fd); memset(next_frame, '\0', in_height * in_width * fb_pixel_size); --- 830,842 ---- static void uninit(void) { ! if (verbose > 0) ! printf("fbdev: uninit\n"); if (fb_oldcmap) { if (ioctl(fb_dev_fd, FBIOPUTCMAP, fb_oldcmap)) ! printf("fbdev: Can't restore original cmap\n"); fb_oldcmap = NULL; } ! if (ioctl(fb_dev_fd, FBIOPUT_VSCREENINFO, &fb_orig_vinfo)) ! printf("fbdev: Can't set virtual screensize to original value: %s\n", strerror(errno)); close(fb_dev_fd); memset(next_frame, '\0', in_height * in_width * fb_pixel_size); _______________________________________________ Mplayer-cvslog mailing list Mplayer-cvslog@lists.sourceforge.net http://lists.sourceforge.net/lists/listinfo/mplayer-cvslog
participants (1)
-
Szabolcs Berecz