summaryrefslogtreecommitdiffstats
path: root/src/grabbers
diff options
context:
space:
mode:
authorMatthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de>2011-03-18 10:42:11 +0100
committerMatthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de>2011-03-18 10:42:11 +0100
commita95fb6dad12ef73b05e79198763465f418090e99 (patch)
tree08cc1f9d142c1352570958518dfb874aa1e841c7 /src/grabbers
parent384d9c7e478ed9b6b64b050a4251475519fc9580 (diff)
downloadlibuca-a95fb6dad12ef73b05e79198763465f418090e99.tar.gz
libuca-a95fb6dad12ef73b05e79198763465f418090e99.tar.bz2
libuca-a95fb6dad12ef73b05e79198763465f418090e99.tar.xz
libuca-a95fb6dad12ef73b05e79198763465f418090e99.zip
Add (possible) meta data transmission and integrate callback in pco and pf
Diffstat (limited to 'src/grabbers')
-rw-r--r--src/grabbers/me4.c26
1 files changed, 18 insertions, 8 deletions
diff --git a/src/grabbers/me4.c b/src/grabbers/me4.c
index 03a0a3c..8868deb 100644
--- a/src/grabbers/me4.c
+++ b/src/grabbers/me4.c
@@ -9,9 +9,13 @@
#include "uca-grabber.h"
struct fg_apc_data {
- Fg_Struct *fg;
- dma_mem *mem;
- uca_grabber_grab_callback cb;
+ Fg_Struct *fg;
+ dma_mem *mem;
+
+ /* End-user related callback variables */
+ uca_cam_grab_callback callback;
+ void *meta_data;
+ void *user;
};
struct uca_sisofg_map_t {
@@ -149,15 +153,19 @@ uint32_t uca_me4_grab(struct uca_grabber *grabber, void **buffer, uint32_t *fram
static int uca_me4_callback(frameindex_t frame, struct fg_apc_data *apc)
{
- apc->cb(frame, Fg_getImagePtr(apc->fg, frame, PORT_A));
+ apc->callback(frame, Fg_getImagePtr(apc->fg, frame, PORT_A), apc->meta_data, apc->user);
return 0;
}
-uint32_t uca_me4_register_callback(struct uca_grabber *grabber, uca_grabber_grab_callback cb)
+uint32_t uca_me4_register_callback(struct uca_grabber *grabber, uca_cam_grab_callback callback, void *meta_data, void *user)
{
if (grabber->callback == NULL) {
- grabber->callback = cb;
- ((struct fg_apc_data *) grabber->user)->cb = cb;
+ grabber->callback = callback;
+
+ struct fg_apc_data *apc_data = (struct fg_apc_data *) grabber->user;
+ apc_data->callback = callback;
+ apc_data->meta_data = meta_data;
+ apc_data->user = user;
struct FgApcControl ctrl;
ctrl.version = 0;
@@ -186,7 +194,9 @@ uint32_t uca_me4_init(struct uca_grabber **grabber)
me4->fg = fg;
me4->mem = NULL;
- me4->cb = NULL;
+ me4->callback = NULL;
+ me4->meta_data = NULL;
+ me4->user = NULL;
uca->user = me4;
uca->destroy = &uca_me4_destroy;