fix: handle VIDIOC_QBUF error while reading video
This commit is contained in:
+9
-5
@@ -306,11 +306,15 @@ static unsigned int read_video(VideoCapture *video_capture) {
|
||||
|
||||
if (ioctl(video_capture->fd, VIDIOC_DQBUF,
|
||||
&video_capture->buf[video_capture->buf_index]) != -1) {
|
||||
ioctl(video_capture->fd, VIDIOC_QBUF,
|
||||
&video_capture->buf[video_capture->buf_index]);
|
||||
video_capture->buf_index =
|
||||
(video_capture->buf_index + 1) % video_capture->buf_count;
|
||||
return true;
|
||||
if (ioctl(video_capture->fd, VIDIOC_QBUF,
|
||||
&video_capture->buf[video_capture->buf_index]) == -1) {
|
||||
video_capture->error = true;
|
||||
return false;
|
||||
} else {
|
||||
video_capture->buf_index =
|
||||
(video_capture->buf_index + 1) % video_capture->buf_count;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
if (ioctl(video_capture->fd, VIDIOC_QUERYCAP, &cap) == -1) {
|
||||
|
||||
Reference in New Issue
Block a user