1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
/**
* @file vidbridge/src.c Video bridge -- source
*
* Copyright (C) 2010 Creytiv.com
*/
#include <re.h>
#include <rem.h>
#include <baresip.h>
#include "vidbridge.h"
static void destructor(void *arg)
{
struct vidsrc_st *st = arg;
if (st->vidisp)
st->vidisp->vidsrc = NULL;
list_unlink(&st->le);
mem_deref(st->device);
}
int vidbridge_src_alloc(struct vidsrc_st **stp, const struct vidsrc *vs,
struct media_ctx **ctx, struct vidsrc_prm *prm,
const struct vidsz *size, const char *fmt,
const char *dev, vidsrc_frame_h *frameh,
vidsrc_error_h *errorh, void *arg)
{
struct vidsrc_st *st;
int err;
(void)ctx;
(void)prm;
(void)fmt;
(void)errorh;
if (!stp || !size || !frameh)
return EINVAL;
st = mem_zalloc(sizeof(*st), destructor);
if (!st)
return ENOMEM;
st->vs = vs;
st->frameh = frameh;
st->arg = arg;
err = str_dup(&st->device, dev);
if (err)
goto out;
/* find a vidisp device with same name */
st->vidisp = vidbridge_disp_find(dev);
if (st->vidisp) {
st->vidisp->vidsrc = st;
}
hash_append(ht_src, hash_joaat_str(dev), &st->le, st);
out:
if (err)
mem_deref(st);
else
*stp = st;
return err;
}
static bool list_apply_handler(struct le *le, void *arg)
{
struct vidsrc_st *st = le->data;
return 0 == str_cmp(st->device, arg);
}
struct vidsrc_st *vidbridge_src_find(const char *device)
{
return list_ledata(hash_lookup(ht_src, hash_joaat_str(device),
list_apply_handler, (void *)device));
}
void vidbridge_src_input(const struct vidsrc_st *st,
const struct vidframe *frame)
{
if (!st || !frame)
return;
if (st->frameh)
st->frameh((struct vidframe *)frame, st->arg);
}
|