PipeWire 0.3.36
build/doc/spa/monitor/utils.h
Go to the documentation of this file.
1/* Simple Plugin API
2 *
3 * Copyright © 2019 Wim Taymans
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9 * and/or sell copies of the Software, and to permit persons to whom the
10 * Software is furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice (including the next
13 * paragraph) shall be included in all copies or substantial portions of the
14 * Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 * DEALINGS IN THE SOFTWARE.
23 */
24
25#ifndef SPA_DEVICE_UTILS_H
26#define SPA_DEVICE_UTILS_H
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
32#include <spa/pod/builder.h>
33#include <spa/monitor/device.h>
34
38};
39
40/* static */ inline void spa_result_func_device_params(void *data, int seq, int res,
41 uint32_t type, const void *result)
42{
45 const struct spa_result_device_params *r =
46 (const struct spa_result_device_params *)result;
47 uint32_t offset = d->builder->state.offset;
49 return;
50 d->data.next = r->next;
51 d->data.param = spa_pod_builder_deref(d->builder, offset);
52}
53
54/* static */ inline int spa_device_enum_params_sync(struct spa_device *device,
55 uint32_t id, uint32_t *index,
56 const struct spa_pod *filter,
57 struct spa_pod **param,
58 struct spa_pod_builder *builder)
59{
61 struct spa_hook listener = {{0}};
62 static const struct spa_device_events device_events = {
64 .info = NULL,
66 };
67 int res;
68
69 spa_device_add_listener(device, &listener, &device_events, &data);
70 res = spa_device_enum_params(device, 0, id, *index, 1, filter);
71 spa_hook_remove(&listener);
72
73 if (data.data.param == NULL) {
74 if (res > 0)
75 res = 0;
76 } else {
77 *index = data.data.next;
78 *param = data.data.param;
79 res = 1;
80 }
81 return res;
82}
83
84#define spa_device_emit(hooks,method,version,...) \
85 spa_hook_list_call_simple(hooks, struct spa_device_events, \
86 method, version, ##__VA_ARGS__)
87
88#define spa_device_emit_info(hooks,i) spa_device_emit(hooks,info, 0, i)
89#define spa_device_emit_result(hooks,s,r,t,res) spa_device_emit(hooks,result, 0, s, r, t, res)
90#define spa_device_emit_event(hooks,e) spa_device_emit(hooks,event, 0, e)
91#define spa_device_emit_object_info(hooks,id,i) spa_device_emit(hooks,object_info, 0, id, i)
92
93#ifdef __cplusplus
94} /* extern "C" */
95#endif
96
97#endif /* SPA_DEVICE_UTILS_H */
#define SPA_VERSION_DEVICE_EVENTS
version of the structure
Definition: build/doc/spa/monitor/device.h:119
int spa_device_enum_params_sync(struct spa_device *device, uint32_t id, uint32_t *index, const struct spa_pod *filter, struct spa_pod **param, struct spa_pod_builder *builder)
Definition: build/doc/spa/monitor/utils.h:54
void spa_result_func_device_params(void *data, int seq, int res, uint32_t type, const void *result)
Definition: build/doc/spa/monitor/utils.h:40
#define spa_device_enum_params(d,...)
Definition: build/doc/spa/monitor/device.h:255
#define spa_device_add_listener(d,...)
Definition: build/doc/spa/monitor/device.h:253
void spa_hook_remove(struct spa_hook *hook)
Remove a hook.
Definition: hook.h:336
struct spa_pod * spa_pod_builder_deref(struct spa_pod_builder *builder, uint32_t offset)
Definition: builder.h:102
int spa_pod_builder_raw_padded(struct spa_pod_builder *builder, const void *data, uint32_t size)
Definition: builder.h:167
#define SPA_POD_SIZE(pod)
Definition: pod/pod.h:42
user data to add to an object
Definition: media-session.c:110
Definition: alsa-endpoint.c:112
Definition: filter.c:126
Definition: media-session.c:116
spa_device_events:
Definition: build/doc/spa/monitor/device.h:117
uint32_t version
Definition: build/doc/spa/monitor/device.h:120
Definition: build/doc/spa/monitor/device.h:53
A hook, contains the structure with functions and the data passed to the functions.
Definition: hook.h:295
uint32_t offset
Definition: builder.h:47
Definition: builder.h:63
struct spa_pod_builder_state state
Definition: builder.h:67
Definition: pod/pod.h:50
Definition: build/doc/spa/monitor/utils.h:35
struct spa_result_device_params data
Definition: build/doc/spa/monitor/utils.h:37
struct spa_pod_builder * builder
Definition: build/doc/spa/monitor/utils.h:36
Definition: build/doc/spa/monitor/device.h:99
uint32_t index
Definition: build/doc/spa/monitor/device.h:101
uint32_t next
Definition: build/doc/spa/monitor/device.h:102
struct spa_pod * param
Definition: build/doc/spa/monitor/device.h:103