PipeWire 0.3.65
pod/pod.h
Go to the documentation of this file.
1/* Simple Plugin API
2 *
3 * Copyright © 2018 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_POD_H
26#define SPA_POD_H
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
32#include <spa/utils/defs.h>
33#include <spa/utils/type.h>
34
40#define SPA_POD_BODY_SIZE(pod) (((struct spa_pod*)(pod))->size)
41#define SPA_POD_TYPE(pod) (((struct spa_pod*)(pod))->type)
42#define SPA_POD_SIZE(pod) ((uint64_t)sizeof(struct spa_pod) + SPA_POD_BODY_SIZE(pod))
43#define SPA_POD_CONTENTS_SIZE(type,pod) (SPA_POD_SIZE(pod)-sizeof(type))
44
45#define SPA_POD_CONTENTS(type,pod) SPA_PTROFF((pod),sizeof(type),void)
46#define SPA_POD_CONTENTS_CONST(type,pod) SPA_PTROFF((pod),sizeof(type),const void)
47#define SPA_POD_BODY(pod) SPA_PTROFF((pod),sizeof(struct spa_pod),void)
48#define SPA_POD_BODY_CONST(pod) SPA_PTROFF((pod),sizeof(struct spa_pod),const void)
49
50struct spa_pod {
51 uint32_t size; /* size of the body */
52 uint32_t type; /* a basic id of enum spa_type */
53};
54
55#define SPA_POD_VALUE(type,pod) (((type*)(pod))->value)
56
58 struct spa_pod pod;
59 int32_t value;
60 int32_t _padding;
61};
62
63struct spa_pod_id {
64 struct spa_pod pod;
65 uint32_t value;
66 int32_t _padding;
67};
68
70 struct spa_pod pod;
71 int32_t value;
72 int32_t _padding;
73};
75struct spa_pod_long {
76 struct spa_pod pod;
77 int64_t value;
78};
81 struct spa_pod pod;
82 float value;
83 int32_t _padding;
84};
87 struct spa_pod pod;
88 double value;
89};
92 struct spa_pod pod;
93 /* value here */
94};
97 struct spa_pod pod;
98 /* value here */
99};
102 struct spa_pod pod;
103 struct spa_rectangle value;
104};
107 struct spa_pod pod;
108 struct spa_fraction value;
109};
112 struct spa_pod pod;
113 /* array of uint8_t follows with the bitmap */
114};
116#define SPA_POD_ARRAY_CHILD(arr) (&((struct spa_pod_array*)(arr))->body.child)
117#define SPA_POD_ARRAY_VALUE_TYPE(arr) (SPA_POD_TYPE(SPA_POD_ARRAY_CHILD(arr)))
118#define SPA_POD_ARRAY_VALUE_SIZE(arr) (SPA_POD_BODY_SIZE(SPA_POD_ARRAY_CHILD(arr)))
119#define SPA_POD_ARRAY_N_VALUES(arr) (SPA_POD_ARRAY_VALUE_SIZE(arr) ? ((SPA_POD_BODY_SIZE(arr) - sizeof(struct spa_pod_array_body)) / SPA_POD_ARRAY_VALUE_SIZE(arr)) : 0)
120#define SPA_POD_ARRAY_VALUES(arr) SPA_POD_CONTENTS(struct spa_pod_array, arr)
123 struct spa_pod child;
124 /* array with elements of child.size follows */
127struct spa_pod_array {
128 struct spa_pod pod;
130};
132#define SPA_POD_CHOICE_CHILD(choice) (&((struct spa_pod_choice*)(choice))->body.child)
133#define SPA_POD_CHOICE_TYPE(choice) (((struct spa_pod_choice*)(choice))->body.type)
134#define SPA_POD_CHOICE_FLAGS(choice) (((struct spa_pod_choice*)(choice))->body.flags)
135#define SPA_POD_CHOICE_VALUE_TYPE(choice) (SPA_POD_TYPE(SPA_POD_CHOICE_CHILD(choice)))
136#define SPA_POD_CHOICE_VALUE_SIZE(choice) (SPA_POD_BODY_SIZE(SPA_POD_CHOICE_CHILD(choice)))
137#define SPA_POD_CHOICE_N_VALUES(choice) (SPA_POD_CHOICE_VALUE_SIZE(choice) ? ((SPA_POD_BODY_SIZE(choice) - sizeof(struct spa_pod_choice_body)) / SPA_POD_CHOICE_VALUE_SIZE(choice)) : 0)
138#define SPA_POD_CHOICE_VALUES(choice) (SPA_POD_CONTENTS(struct spa_pod_choice, choice))
140enum spa_choice_type {
149 uint32_t type;
150 uint32_t flags;
151 struct spa_pod child;
152 /* array with elements of child.size follows. Note that there might be more
153 * elements than required by \a type, which should be ignored. */
155
157 struct spa_pod pod;
159};
161struct spa_pod_struct {
162 struct spa_pod pod;
163 /* one or more spa_pod follow */
165
166#define SPA_POD_OBJECT_TYPE(obj) (((struct spa_pod_object*)(obj))->body.type)
167#define SPA_POD_OBJECT_ID(obj) (((struct spa_pod_object*)(obj))->body.id)
170 uint32_t type;
171 uint32_t id;
172 /* contents follow, series of spa_pod_prop */
173};
176 struct spa_pod pod;
178};
179
181 uint32_t type;
182 uint32_t _padding;
183 const void *value;
185
186struct spa_pod_pointer {
187 struct spa_pod pod;
189};
190
191struct spa_pod_fd {
192 struct spa_pod pod;
193 int64_t value;
194};
196#define SPA_POD_PROP_SIZE(prop) (sizeof(struct spa_pod_prop) + (prop)->value.size)
198/* props can be inside an object */
200 uint32_t key;
202#define SPA_POD_PROP_FLAG_READONLY (1u<<0)
203#define SPA_POD_PROP_FLAG_HARDWARE (1u<<1)
204#define SPA_POD_PROP_FLAG_HINT_DICT (1u<<2)
209#define SPA_POD_PROP_FLAG_MANDATORY (1u<<3)
210#define SPA_POD_PROP_FLAG_DONT_FIXATE (1u<<4)
211 uint32_t flags;
212 struct spa_pod value;
213 /* value follows */
216#define SPA_POD_CONTROL_SIZE(ev) (sizeof(struct spa_pod_control) + (ev)->value.size)
217
218/* controls can be inside a sequence and mark timed values */
220 uint32_t offset;
221 uint32_t type;
222 struct spa_pod value;
223 /* value contents follow */
224};
227 uint32_t unit;
228 uint32_t pad;
229 /* series of struct spa_pod_control follows */
230};
231
233struct spa_pod_sequence {
234 struct spa_pod pod;
236};
237
242#ifdef __cplusplus
243} /* extern "C" */
244#endif
246#endif /* SPA_POD_H */
spa/utils/defs.h
spa_choice_type
Definition: pod/pod.h:166
@ SPA_CHOICE_Step
range with step: default, min, max, step
Definition: pod/pod.h:169
@ SPA_CHOICE_None
no choice, first value is current
Definition: pod/pod.h:167
@ SPA_CHOICE_Flags
flags: default, possible flags,...
Definition: pod/pod.h:171
@ SPA_CHOICE_Range
range: default, min, max
Definition: pod/pod.h:168
@ SPA_CHOICE_Enum
list: default, alternative,...
Definition: pod/pod.h:170
spa/utils/type.h
Definition: defs.h:139
Definition: pod/pod.h:141
struct spa_pod child
Definition: pod/pod.h:142
Definition: pod/pod.h:146
struct spa_pod pod
Definition: pod/pod.h:147
struct spa_pod_array_body body
Definition: pod/pod.h:148
Definition: pod/pod.h:125
struct spa_pod pod
Definition: pod/pod.h:126
Definition: pod/pod.h:71
int32_t _padding
Definition: pod/pod.h:74
int32_t value
Definition: pod/pod.h:73
struct spa_pod pod
Definition: pod/pod.h:72
Definition: pod/pod.h:110
struct spa_pod pod
Definition: pod/pod.h:111
Definition: pod/pod.h:174
struct spa_pod child
Definition: pod/pod.h:177
uint32_t type
type of choice, one of enum spa_choice_type
Definition: pod/pod.h:175
uint32_t flags
extra flags
Definition: pod/pod.h:176
Definition: pod/pod.h:182
struct spa_pod_choice_body body
Definition: pod/pod.h:184
struct spa_pod pod
Definition: pod/pod.h:183
Definition: pod/pod.h:254
struct spa_pod value
control value, depends on type
Definition: pod/pod.h:257
uint32_t type
type of control, enum spa_control_type
Definition: pod/pod.h:256
uint32_t offset
media offset
Definition: pod/pod.h:255
Definition: pod/pod.h:100
double value
Definition: pod/pod.h:102
struct spa_pod pod
Definition: pod/pod.h:101
Definition: pod/pod.h:219
int64_t value
Definition: pod/pod.h:221
struct spa_pod pod
Definition: pod/pod.h:220
Definition: pod/pod.h:94
int32_t _padding
Definition: pod/pod.h:97
struct spa_pod pod
Definition: pod/pod.h:95
float value
Definition: pod/pod.h:96
Definition: pod/pod.h:120
struct spa_fraction value
Definition: pod/pod.h:122
struct spa_pod pod
Definition: pod/pod.h:121
Definition: pod/pod.h:77
uint32_t value
Definition: pod/pod.h:79
int32_t _padding
Definition: pod/pod.h:80
struct spa_pod pod
Definition: pod/pod.h:78
Definition: pod/pod.h:83
struct spa_pod pod
Definition: pod/pod.h:84
int32_t _padding
Definition: pod/pod.h:86
int32_t value
Definition: pod/pod.h:85
Definition: pod/pod.h:89
int64_t value
Definition: pod/pod.h:91
struct spa_pod pod
Definition: pod/pod.h:90
Definition: pod/pod.h:197
uint32_t type
one of enum spa_type
Definition: pod/pod.h:198
uint32_t id
id of the object, depends on the object type
Definition: pod/pod.h:199
Definition: pod/pod.h:203
struct spa_pod pod
Definition: pod/pod.h:204
struct spa_pod_object_body body
Definition: pod/pod.h:205
Definition: pod/pod.h:208
const void * value
Definition: pod/pod.h:211
uint32_t _padding
Definition: pod/pod.h:210
uint32_t type
pointer id, one of enum spa_type
Definition: pod/pod.h:209
Definition: pod/pod.h:214
struct spa_pod_pointer_body body
Definition: pod/pod.h:216
struct spa_pod pod
Definition: pod/pod.h:215
Definition: pod/pod.h:228
uint32_t key
key of property, list of valid keys depends on the object type
Definition: pod/pod.h:229
uint32_t flags
flags for property
Definition: pod/pod.h:245
struct spa_pod value
Definition: pod/pod.h:246
Definition: pod/pod.h:115
struct spa_pod pod
Definition: pod/pod.h:116
struct spa_rectangle value
Definition: pod/pod.h:117
Definition: pod/pod.h:261
uint32_t pad
Definition: pod/pod.h:263
uint32_t unit
Definition: pod/pod.h:262
a sequence of timed controls
Definition: pod/pod.h:268
struct spa_pod pod
Definition: pod/pod.h:269
struct spa_pod_sequence_body body
Definition: pod/pod.h:270
Definition: pod/pod.h:105
struct spa_pod pod
Definition: pod/pod.h:106
Definition: pod/pod.h:187
struct spa_pod pod
Definition: pod/pod.h:188
Definition: pod/pod.h:63
uint32_t type
Definition: pod/pod.h:65
uint32_t size
Definition: pod/pod.h:64
Definition: defs.h:118