]> git.sesse.net Git - ffmpeg/commitdiff
lavd/fbdev_enc: add default device
authorLukasz Marek <lukasz.m.luki@gmail.com>
Thu, 7 Nov 2013 18:06:38 +0000 (19:06 +0100)
committerLukasz Marek <lukasz.m.luki@gmail.com>
Fri, 6 Dec 2013 18:15:47 +0000 (19:15 +0100)
Use device specified by environment variable FRAMEBUFFER or /dev/fb0 as default.

Signed-off-by: Lukasz Marek <lukasz.m.luki@gmail.com>
libavdevice/fbdev_common.c
libavdevice/fbdev_common.h
libavdevice/fbdev_enc.c

index eb8f3d2581a139c254649d5212762476a6ab44e2..45ae08b69839b4f93dd4858be9b07ee6baf9f505 100644 (file)
@@ -20,6 +20,7 @@
  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  */
 
+#include <stdlib.h>
 #include "fbdev_common.h"
 #include "libavutil/common.h"
 
@@ -55,3 +56,12 @@ enum AVPixelFormat ff_get_pixfmt_from_fb_varinfo(struct fb_var_screeninfo *varin
 
     return AV_PIX_FMT_NONE;
 }
+
+const char* ff_fbdev_default_device()
+{
+    const char *dev = getenv("FRAMEBUFFER");
+    if (!dev)
+        dev = "/dev/fb0";
+    return dev;
+}
+
index b6eea2f1c191c32c32c3694b543da468b4c2893f..40a1ded847cd69a5f9cc4cee770fc9e8219ec0cb 100644 (file)
@@ -29,4 +29,6 @@
 
 enum AVPixelFormat ff_get_pixfmt_from_fb_varinfo(struct fb_var_screeninfo *varinfo);
 
+const char* ff_fbdev_default_device(void);
+
 #endif /* AVDEVICE_FBDEV_COMMON_H */
index 098eedb5f5e6c5d2d8cc2697f247a4c93bbf984c..8291b597596c2f6ee7ca195b70379b1cd7e52054 100644 (file)
@@ -45,17 +45,23 @@ static av_cold int fbdev_write_header(AVFormatContext *h)
     FBDevContext *fbdev = h->priv_data;
     enum AVPixelFormat pix_fmt;
     int ret, flags = O_RDWR;
+    const char* device;
 
     if (h->nb_streams != 1 || h->streams[0]->codec->codec_type != AVMEDIA_TYPE_VIDEO) {
         av_log(fbdev, AV_LOG_ERROR, "Only a single video stream is supported.\n");
         return AVERROR(EINVAL);
     }
 
-    if ((fbdev->fd = avpriv_open(h->filename, flags)) == -1) {
+    if (h->filename[0])
+        device = h->filename;
+    else
+        device = ff_fbdev_default_device();
+
+    if ((fbdev->fd = avpriv_open(device, flags)) == -1) {
         ret = AVERROR(errno);
         av_log(h, AV_LOG_ERROR,
                "Could not open framebuffer device '%s': %s\n",
-               h->filename, av_err2str(ret));
+               device, av_err2str(ret));
         return ret;
     }