summaryrefslogtreecommitdiffstats
path: root/reader.c
diff options
context:
space:
mode:
authorSuren A. Chilingaryan <csa@suren.me>2015-08-14 03:53:15 +0200
committerSuren A. Chilingaryan <csa@suren.me>2015-08-14 03:53:15 +0200
commitfe3f8e3e172818741f32f5ea0bba27f77ca56a1a (patch)
tree0668d3f220a0c1c9a8b7e221595101638ab598c3 /reader.c
parent280522822611d16c87e9931f8807878fc023e97d (diff)
downloadipecamera-fe3f8e3e172818741f32f5ea0bba27f77ca56a1a.tar.gz
ipecamera-fe3f8e3e172818741f32f5ea0bba27f77ca56a1a.tar.bz2
ipecamera-fe3f8e3e172818741f32f5ea0bba27f77ca56a1a.tar.xz
ipecamera-fe3f8e3e172818741f32f5ea0bba27f77ca56a1a.zip
Add another workaround to handle cameras stuck in busy (disabled and untested)
Diffstat (limited to 'reader.c')
-rw-r--r--reader.c36
1 files changed, 35 insertions, 1 deletions
diff --git a/reader.c b/reader.c
index b603e47..3e2b444 100644
--- a/reader.c
+++ b/reader.c
@@ -21,6 +21,23 @@
#include "private.h"
#include "reader.h"
+
+#define GET_REG(reg, var) \
+ if (!err) { \
+ err = pcilib_read_register_by_id(pcilib, ctx->reg, &var); \
+ if (err) { \
+ pcilib_error("Error reading %s register", model_info->registers[ctx->reg].name); \
+ } \
+ }
+
+#define SET_REG(reg, val) \
+ if (!err) { \
+ err = pcilib_write_register_by_id(pcilib, ctx->reg, val); \
+ if (err) { \
+ pcilib_error("Error writting %s register", model_info->registers[ctx->reg].name); \
+ } \
+ }
+
//#define CHECK_FRAME_MAGIC(buf) \
// memcmp(buf, ((void*)frame_magic) + 1, sizeof(frame_magic) - 1)
@@ -304,7 +321,12 @@ static int ipecamera_data_callback(void *user, pcilib_dma_flags_t flags, size_t
void *ipecamera_reader_thread(void *user) {
int err;
ipecamera_t *ctx = (ipecamera_t*)user;
-
+#ifdef IPECAMERA_BUG_STUCKED_BUSY
+ pcilib_register_value_t saved, value;
+ pcilib_t *pcilib = ctx->event.pcilib;
+ const pcilib_model_description_t *model_info = pcilib_get_model_description(pcilib);
+#endif /* IPECAMERA_BUG_STUCKED_BUSY */
+
while (ctx->run_reader) {
err = pcilib_stream_dma(ctx->event.pcilib, ctx->rdma, 0, 0, PCILIB_DMA_FLAG_MULTIPACKET, IPECAMERA_DMA_TIMEOUT, &ipecamera_data_callback, user);
if (err) {
@@ -317,6 +339,18 @@ void *ipecamera_reader_thread(void *user) {
ctx->run_reader = 0;
break;
}
+#ifdef IPECAMERA_BUG_STUCKED_BUSY
+ GET_REG(status2_reg, value);
+ if (value&0x2FFFFFFF) {
+ pcilib_warning("Camera stuck in busy, trying to recover...");
+ GET_REG(control_reg, saved);
+ SET_REG(control_reg, IPECAMERA_IDLE);
+ while ((value&0x2FFFFFFF)&&(ctx->run_reader)) {
+ usleep(IPECAMERA_NOFRAME_SLEEP);
+ }
+ return 0;
+ }
+#endif /* IPECAMERA_BUG_STUCKED_BUSY */
usleep(IPECAMERA_NOFRAME_SLEEP);
} else pcilib_error("DMA error while reading IPECamera frames, error: %i", err);
}