From f49e48763142b94af444615d5f5d5f8783a4e052 Mon Sep 17 00:00:00 2001 From: luigi Date: Wed, 7 Feb 2007 00:45:08 +0000 Subject: Enable proper detection of video4linux devices. The original code detects video devices using the major/minor numbers. On FreeBSD this does not work, so rely on the name /dev/video* instead. Approved by: Steve Ames --- .../patch-plugins-vidinput_v4l-vidinput_v4l.cxx | 26 ++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 devel/pwlib/files/patch-plugins-vidinput_v4l-vidinput_v4l.cxx (limited to 'devel') diff --git a/devel/pwlib/files/patch-plugins-vidinput_v4l-vidinput_v4l.cxx b/devel/pwlib/files/patch-plugins-vidinput_v4l-vidinput_v4l.cxx new file mode 100644 index 00000000000..11c6e52b70d --- /dev/null +++ b/devel/pwlib/files/patch-plugins-vidinput_v4l-vidinput_v4l.cxx @@ -0,0 +1,26 @@ +--- plugins/vidinput_v4l/vidinput_v4l.cxx.orig Wed Jan 3 23:37:37 2007 ++++ plugins/vidinput_v4l/vidinput_v4l.cxx Wed Feb 7 01:30:50 2007 +@@ -484,6 +484,15 @@ + struct stat s; + if (lstat(devname, &s) == 0) { + ++#if defined(P_FREEBSD) ++ // device numbers are irrelevant here, so we match on names instead. ++ if (filename.GetLength() <= 5 || filename.Left(5) != "video") ++ continue; ++ int num = atoi(filename.Mid(6)); ++ if (num < 0 || num > 63) ++ continue; ++ vid.SetAt(num, devname); ++#else + static const int deviceNumbers[] = { 81 }; + for (PINDEX i = 0; i < PARRAYSIZE(deviceNumbers); i++) { + if (MAJOR(s.st_rdev) == deviceNumbers[i]) { +@@ -493,6 +502,7 @@ + } + } + } ++#endif + } + } + } -- cgit