diff options
Diffstat (limited to 'src/video_out/video_out_fb.c')
| -rw-r--r-- | src/video_out/video_out_fb.c | 122 | 
1 files changed, 46 insertions, 76 deletions
| diff --git a/src/video_out/video_out_fb.c b/src/video_out/video_out_fb.c index 95060a4d8..5a49b80a3 100644 --- a/src/video_out/video_out_fb.c +++ b/src/video_out/video_out_fb.c @@ -1,5 +1,5 @@  /* - * Copyright (C) 2000-2003 the xine project and Fredrik Noring + * Copyright (C) 2000-2007 the xine project and Fredrik Noring   *    * This file is part of xine, a free video player.   *  @@ -16,28 +16,28 @@   * You should have received a copy of the GNU General Public License   * along with this program; if not, write to the Free Software   * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA + */ + +/** + * @file + * @brief Frame buffer xine driver   * - * video_out_fb.c, frame buffer xine driver by Miguel Freitas - * - * Contributors: + * @author Miguel Freitas   * - *     Fredrik Noring <noring@nocrew.org>:  Zero copy buffers and clean up. + * @author Fredrik Noring <noring@nocrew.org>: + *         Zero copy buffers and clean up.   * - * based on xine's video_out_xshm.c... - * ...based on mpeg2dec code from - * Aaron Holtzman <aholtzma@ess.engr.uvic.ca> + * @author Aaron Holtzman <aholtzma@ess.engr.uvic.ca>:  + *         Based on xine's video_out_xshm.c, based on mpeg2dec code from   * - * ideas from ppmtofb - Display P?M graphics on framebuffer devices - *            by Geert Uytterhoeven and Chris Lawrence + * @author Geert Uytterhoeven and Chris Lawrence: + *         Ideas from ppmtofb - Display P?M graphics on framebuffer devices.   * - * Note: Use this with fbxine. It may work with the regular xine too, - * provided the visual type is changed (see below). + * @note Use this with fbxine.   * - * TODO: VT switching (configurable) + * @todo VT Switching (configurable)   */ -/* #define USE_X11_VISUAL */ -  #define RECOMMENDED_NUM_BUFFERS  5  #define MAXIMUM_NUM_BUFFERS     25 @@ -55,7 +55,7 @@  #include <fcntl.h>   #include "xine.h" -#include "video_out.h" +#include <xine/video_out.h>  #include <errno.h> @@ -78,10 +78,10 @@  #define LOG  */ -#include "xine_internal.h" +#include <xine/xine_internal.h>  #include "yuv2rgb.h" -#include "xineutils.h" -#include "vo_scale.h" +#include <xine/xineutils.h> +#include <xine/vo_scale.h>  typedef struct fb_frame_s  { @@ -155,7 +155,7 @@ typedef struct  static uint32_t fb_get_capabilities(vo_driver_t *this_gen)  { -  return VO_CAP_YV12 | VO_CAP_YUY2; +  return VO_CAP_YV12 | VO_CAP_YUY2 | VO_CAP_BRIGHTNESS | VO_CAP_CONTRAST | VO_CAP_SATURATION;  }  static void fb_frame_proc_slice(vo_frame_t *vo_img, uint8_t **src) @@ -324,21 +324,10 @@ static void setup_colorspace_converter(fb_frame_t *frame, int flags)  static void frame_reallocate(fb_driver_t *this, fb_frame_t *frame,  			     uint32_t width, uint32_t height, int format)  { -  if(frame->chunk[0]) -  { -    free(frame->chunk[0]); -        frame->chunk[0] = NULL; -  } -  if(frame->chunk[1]) -  { -    free(frame->chunk[1]); -        frame->chunk[1] = NULL; -  } -  if(frame->chunk[2]) -  { -    free(frame->chunk[2]); -        frame->chunk[2] = NULL; -  } +  free(frame->chunk[0]); +  free(frame->chunk[1]); +  free(frame->chunk[2]); +  memset(frame->chunk, 0, sizeof(frame->chunk[0])*3);    if(this->use_zero_copy)    { @@ -348,10 +337,9 @@ static void frame_reallocate(fb_driver_t *this, fb_frame_t *frame,    }    else    { -    if(frame->data) -      free(frame->data); -    frame->data = xine_xmalloc(frame->sc.output_width * -			       frame->sc.output_height * +    free(frame->data); +    frame->data = xine_xcalloc(frame->sc.output_width * +			       frame->sc.output_height,  			       this->bytes_per_pixel);    } @@ -440,7 +428,7 @@ static void fb_update_frame_format(vo_driver_t *this_gen,  static void fb_overlay_clut_yuv2rgb(fb_driver_t *this,  				    vo_overlay_t *overlay, fb_frame_t *frame)  { -  int i; +  size_t i;    clut_t* clut = (clut_t*)overlay->color;    if(!overlay->rgb_clut) @@ -644,7 +632,7 @@ static int fb_set_property(vo_driver_t *this_gen, int property, int value)  	value = XINE_VO_ASPECT_AUTO;        this->sc.user_ratio = value;        xprintf(this->xine, XINE_VERBOSITY_DEBUG,  -	      "video_out_fb: aspect ratio changed to %s\n", _x_vo_scale_aspect_ratio_name(value)); +	      "video_out_fb: aspect ratio changed to %s\n", _x_vo_scale_aspect_ratio_name_table[value]);        break;      case VO_PROP_BRIGHTNESS: @@ -820,8 +808,8 @@ static void register_callbacks(fb_driver_t *this)  static int open_fb_device(config_values_t *config, xine_t *xine)  { -  static char devkey[] = "video.device.fb_device";   /* Why static? */ -  char *device_name; +  static const char devkey[] = "video.device.fb_device"; +  const char *device_name;    int fd;    /* This config entry is security critical, is it really necessary @@ -902,7 +890,7 @@ static int mode_visual(fb_driver_t *this, config_values_t *config,        }    } -  xprintf(this->xine, XINE_VERBOSITY_LOG, _("video_out_fb: Your video mode was not recognized, sorry.\n")); +  xprintf(this->xine, XINE_VERBOSITY_LOG, _("%s: Your video mode was not recognized, sorry.\n"), LOG_MODULE);    return 0;  } @@ -959,16 +947,16 @@ static void setup_buffers(fb_driver_t *this,    this->cur_frame = this->old_frame = 0;    xprintf(this->xine, XINE_VERBOSITY_LOG, -	  _("video_out_fb: %d video RAM buffers are available.\n"), this->total_num_native_buffers); +	  _("%s: %d video RAM buffers are available.\n"), LOG_MODULE, this->total_num_native_buffers);    if(this->total_num_native_buffers < RECOMMENDED_NUM_BUFFERS)    {      this->use_zero_copy = 0;      xprintf(this->xine, XINE_VERBOSITY_LOG, -	    _("WARNING: video_out_fb: Zero copy buffers are DISABLED because only %d buffers\n" +	    _("WARNING: %s: Zero copy buffers are DISABLED because only %d buffers\n"  	      "     are available which is less than the recommended %d buffers. Lowering\n"  	      "     the frame buffer resolution might help.\n"),  -	    this->total_num_native_buffers, RECOMMENDED_NUM_BUFFERS); +	    LOG_MODULE, this->total_num_native_buffers, RECOMMENDED_NUM_BUFFERS);    }    else    { @@ -976,8 +964,8 @@ static void setup_buffers(fb_driver_t *this,      this->fb_var.yoffset = this->fb_var.yres;      if(ioctl(this->fd, FBIOPAN_DISPLAY, &this->fb_var) == -1) {        xprintf(this->xine, XINE_VERBOSITY_LOG, -	      _("WARNING: video_out_fb: Zero copy buffers are DISABLED because kernel driver\n" -		"     do not support screen panning (used for frame flips).\n")); +	      _("WARNING: %s: Zero copy buffers are DISABLED because kernel driver\n" +		"     do not support screen panning (used for frame flips).\n"), LOG_MODULE);      } else {        this->fb_var.yoffset = 0;        ioctl(this->fd, FBIOPAN_DISPLAY, &this->fb_var); @@ -1045,12 +1033,13 @@ static vo_driver_t *fb_open_plugin(video_driver_class_t *class_gen,    if(this->depth > 16)      xprintf(this->xine, XINE_VERBOSITY_LOG, -	    _("WARNING: video_out_fb: current display depth is %d. For better performance\n" -	      "     a depth of 16 bpp is recommended!\n\n"), this->depth); +	    _("WARNING: %s: current display depth is %d. For better performance\n" +	      "     a depth of 16 bpp is recommended!\n\n"), LOG_MODULE, this->depth);    xprintf(class->xine, XINE_VERBOSITY_DEBUG, -	  "video_out_fb: video mode depth is %d (%d bpp),\n" +	  "%s: video mode depth is %d (%d bpp),\n"  	  "     red: %d/%d, green: %d/%d, blue: %d/%d\n", +	  LOG_MODULE,  	  this->depth, this->bpp,  	  this->fb_var.red.length, this->fb_var.red.offset,  	  this->fb_var.green.length, this->fb_var.green.offset, @@ -1069,30 +1058,14 @@ error:    return 0;  } -static char* fb_get_identifier(video_driver_class_t *this_gen) -{ -  return "fb"; -} - -static char* fb_get_description(video_driver_class_t *this_gen) -{ -  return _("Xine video output plugin using the Linux frame buffer device"); -} - -static void fb_dispose_class(video_driver_class_t *this_gen) -{ -  fb_class_t *this = (fb_class_t *)this_gen; -  free(this); -} -  static void *fb_init_class(xine_t *xine, void *visual_gen)  {    fb_class_t *this = (fb_class_t *)xine_xmalloc(sizeof(fb_class_t));    this->driver_class.open_plugin     = fb_open_plugin; -  this->driver_class.get_identifier  = fb_get_identifier; -  this->driver_class.get_description = fb_get_description; -  this->driver_class.dispose         = fb_dispose_class; +  this->driver_class.identifier      = "fb"; +  this->driver_class.description     = N_("Xine video output plugin using the Linux frame buffer device"); +  this->driver_class.dispose         = default_video_driver_class_dispose;    this->config          = xine->config;    this->xine            = xine; @@ -1103,16 +1076,13 @@ static void *fb_init_class(xine_t *xine, void *visual_gen)  static const vo_info_t vo_info_fb =  {    1,                    /* priority    */ -#ifdef USE_X11_VISUAL -  XINE_VISUAL_TYPE_X11  /* visual type */ -#else    XINE_VISUAL_TYPE_FB   /* visual type */ -#endif  };  /* exported plugin catalog entry */  const plugin_info_t xine_plugin_info[] EXPORTED = {    /* type, API, "name", version, special_info, init_function */   -  { PLUGIN_VIDEO_OUT, 21, "fb", XINE_VERSION_CODE, &vo_info_fb, fb_init_class }, +  { PLUGIN_VIDEO_OUT, 22, "fb", XINE_VERSION_CODE, &vo_info_fb, fb_init_class },    { PLUGIN_NONE, 0, "", 0, NULL, NULL }  }; + | 
