|
@@ -1,6 +1,9 @@
|
|
|
#include <sys/ioctl.h>
|
|
|
#include <errno.h>
|
|
|
+#include <linux/v4l2-subdev.h>
|
|
|
+#include <stdio.h>
|
|
|
#include "util.h"
|
|
|
+#include "log.h"
|
|
|
|
|
|
int
|
|
|
xioctl(int fd, int request, void *arg)
|
|
@@ -10,4 +13,65 @@ xioctl(int fd, int request, void *arg)
|
|
|
r = ioctl(fd, request, arg);
|
|
|
} while (r == -1 && errno == EINTR);
|
|
|
return r;
|
|
|
-}
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+const char
|
|
|
+*
|
|
|
+v4l2_ctrl_get_name(unsigned int id)
|
|
|
+{
|
|
|
+ switch (id) {
|
|
|
+ case V4L2_CID_FLASH_LED_MODE:
|
|
|
+ return "LED Mode";
|
|
|
+ case V4L2_CID_FLASH_STROBE_SOURCE:
|
|
|
+ return "Strobe Source";
|
|
|
+ case V4L2_CID_FLASH_STROBE:
|
|
|
+ return "Strobe";
|
|
|
+ default:
|
|
|
+ return "Unknown";
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+const char
|
|
|
+*
|
|
|
+v4l2_ctrl_get_menu_value(unsigned int id, signed int val)
|
|
|
+{
|
|
|
+ static const char *const flash_led_mode[] = {
|
|
|
+ "Off",
|
|
|
+ "Flash",
|
|
|
+ "Torch",
|
|
|
+ NULL,
|
|
|
+ };
|
|
|
+ static const char *const flash_strobe_source[] = {
|
|
|
+ "Software",
|
|
|
+ "External",
|
|
|
+ NULL,
|
|
|
+ };
|
|
|
+
|
|
|
+ switch (id) {
|
|
|
+ case V4L2_CID_FLASH_LED_MODE:
|
|
|
+ return flash_led_mode[val];
|
|
|
+ case V4L2_CID_FLASH_STROBE_SOURCE:
|
|
|
+ return flash_strobe_source[val];
|
|
|
+ default:
|
|
|
+ return "None/Unknown";
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+void
|
|
|
+set_control(int fd, unsigned int ctrl_id, signed int ctrl_val)
|
|
|
+{
|
|
|
+ struct v4l2_control ctrl;
|
|
|
+ ctrl.id = ctrl_id;
|
|
|
+ ctrl.value = ctrl_val;
|
|
|
+ int res = xioctl(fd, VIDIOC_S_CTRL, &ctrl);
|
|
|
+ if (res == -1) {
|
|
|
+ log_debug(
|
|
|
+ "Failed to set %s to %s for flash.\n",
|
|
|
+ v4l2_ctrl_get_name(ctrl_id),
|
|
|
+ v4l2_ctrl_get_menu_value(ctrl_id, ctrl_val)
|
|
|
+ );
|
|
|
+ }
|
|
|
+}
|