PipeWire  0.3.33
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
29 extern "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) (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 
50 struct 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 
57 struct spa_pod_bool {
58  struct spa_pod pod;
59  int32_t value;
60  int32_t _padding;
61 };
62 
63 struct spa_pod_id {
64  struct spa_pod pod;
65  uint32_t value;
66  int32_t _padding;
67 };
68 
69 struct spa_pod_int {
70  struct spa_pod pod;
71  int32_t value;
72  int32_t _padding;
73 };
74 
75 struct spa_pod_long {
76  struct spa_pod pod;
77  int64_t value;
78 };
79 
80 struct spa_pod_float {
81  struct spa_pod pod;
82  float value;
83  int32_t _padding;
84 };
85 
87  struct spa_pod pod;
88  double value;
89 };
90 
92  struct spa_pod pod;
93  /* value here */
94 };
95 
96 struct spa_pod_bytes {
97  struct spa_pod pod;
98  /* value here */
99 };
100 
102  struct spa_pod pod;
103  struct spa_rectangle value;
104 };
105 
107  struct spa_pod pod;
108  struct spa_fraction value;
109 };
110 
112  struct spa_pod pod;
113  /* array of uint8_t follows with the bitmap */
114 };
115 
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)
121 
123  struct spa_pod child;
124  /* array with elements of child.size follows */
125 };
126 
128  struct spa_pod pod;
129  struct spa_pod_array_body body;
130 };
131 
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))
139 
146 };
147 
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. */
154 };
155 
157  struct spa_pod pod;
158  struct spa_pod_choice_body body;
159 };
160 
162  struct spa_pod pod;
163  /* one or more spa_pod follow */
164 };
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)
168 
170  uint32_t type;
171  uint32_t id;
172  /* contents follow, series of spa_pod_prop */
173 };
174 
176  struct spa_pod pod;
177  struct spa_pod_object_body body;
178 };
179 
181  uint32_t type;
182  uint32_t _padding;
183  const void *value;
184 };
185 
187  struct spa_pod pod;
188  struct spa_pod_pointer_body body;
189 };
190 
191 struct spa_pod_fd {
192  struct spa_pod pod;
193  int64_t value;
194 };
195 
196 #define SPA_POD_PROP_SIZE(prop) (sizeof(struct spa_pod_prop) + (prop)->value.size)
197 
198 /* props can be inside an object */
199 struct spa_pod_prop {
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 */
214 };
215 
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 };
225 
227  uint32_t unit;
228  uint32_t pad;
229  /* series of struct spa_pod_control follows */
230 };
231 
234  struct spa_pod pod;
236 };
237 
242 #ifdef __cplusplus
243 } /* extern "C" */
244 #endif
245 
246 #endif /* SPA_POD_H */
spa_pod_id::value
uint32_t value
Definition: pod/pod.h:65
spa_pod_object
Definition: pod/pod.h:175
spa_pod_fd
Definition: pod/pod.h:191
spa_pod_choice
Definition: pod/pod.h:156
spa_pod_object_body::type
uint32_t type
one of enum spa_type
Definition: pod/pod.h:170
spa_pod_int
Definition: pod/pod.h:69
SPA_CHOICE_Range
@ SPA_CHOICE_Range
range: default, min, max
Definition: pod/pod.h:142
spa_pod_sequence_body::unit
uint32_t unit
Definition: pod/pod.h:227
spa_pod_id::_padding
int32_t _padding
Definition: pod/pod.h:66
spa_pod_pointer_body
Definition: pod/pod.h:180
spa_pod_id::pod
struct spa_pod pod
Definition: pod/pod.h:64
spa_pod_object_body
Definition: pod/pod.h:169
spa_pod_prop
Definition: pod/pod.h:199
SPA_CHOICE_Enum
@ SPA_CHOICE_Enum
list: default, alternative,...
Definition: pod/pod.h:144
spa_pod_fraction::value
struct spa_fraction value
Definition: pod/pod.h:108
spa_pod_object_body::id
uint32_t id
id of the object, depends on the object type
Definition: pod/pod.h:171
spa_pod_bytes::pod
struct spa_pod pod
Definition: pod/pod.h:97
spa_pod_array::body
struct spa_pod_array_body body
Definition: pod/pod.h:129
spa_pod_double
Definition: pod/pod.h:86
spa_pod_control
Definition: pod/pod.h:219
spa_pod_rectangle::value
struct spa_rectangle value
Definition: pod/pod.h:103
spa_pod_long::value
int64_t value
Definition: pod/pod.h:77
spa_pod_float
Definition: pod/pod.h:80
spa_pod_choice_body::child
struct spa_pod child
Definition: pod/pod.h:151
spa_fraction
Definition: defs.h:104
spa_pod_fraction::pod
struct spa_pod pod
Definition: pod/pod.h:107
spa_pod_bitmap::pod
struct spa_pod pod
Definition: pod/pod.h:112
spa_pod_pointer
Definition: pod/pod.h:186
spa_pod_pointer_body::value
const void * value
Definition: pod/pod.h:183
spa_pod_choice_body
Definition: pod/pod.h:148
spa_pod_struct::pod
struct spa_pod pod
Definition: pod/pod.h:162
spa_pod_int::pod
struct spa_pod pod
Definition: pod/pod.h:70
spa_pod_bitmap
Definition: pod/pod.h:111
spa_pod_sequence_body::pad
uint32_t pad
Definition: pod/pod.h:228
SPA_CHOICE_Flags
@ SPA_CHOICE_Flags
flags: default, possible flags,...
Definition: pod/pod.h:145
spa_pod_long::pod
struct spa_pod pod
Definition: pod/pod.h:76
spa_pod_rectangle
Definition: pod/pod.h:101
spa_pod_array::pod
struct spa_pod pod
Definition: pod/pod.h:128
spa_pod_choice::body
struct spa_pod_choice_body body
Definition: pod/pod.h:158
spa_pod_sequence_body
Definition: pod/pod.h:226
spa_rectangle
Definition: defs.h:86
spa_pod
Definition: pod/pod.h:50
spa_pod_bool
Definition: pod/pod.h:57
spa_pod_bool::pod
struct spa_pod pod
Definition: pod/pod.h:58
spa_pod_float::pod
struct spa_pod pod
Definition: pod/pod.h:81
spa_pod_object::body
struct spa_pod_object_body body
Definition: pod/pod.h:177
spa_pod_control::type
uint32_t type
type of control, enum spa_control_type
Definition: pod/pod.h:221
spa_pod_rectangle::pod
struct spa_pod pod
Definition: pod/pod.h:102
spa_pod_id
Definition: pod/pod.h:63
spa_pod_string
Definition: pod/pod.h:91
spa_pod_array_body
Definition: pod/pod.h:122
spa_choice_type
spa_choice_type
Definition: pod/pod.h:140
spa_pod_pointer_body::type
uint32_t type
pointer id, one of enum spa_type
Definition: pod/pod.h:181
spa_pod_pointer::pod
struct spa_pod pod
Definition: pod/pod.h:187
spa_pod_prop::key
uint32_t key
key of property, list of valid keys depends on the object type
Definition: pod/pod.h:200
spa_pod_array
Definition: pod/pod.h:127
spa_pod_sequence::body
struct spa_pod_sequence_body body
Definition: pod/pod.h:235
spa_pod::size
uint32_t size
Definition: pod/pod.h:51
spa_pod_sequence::pod
struct spa_pod pod
Definition: pod/pod.h:234
spa_pod_control::value
struct spa_pod value
control value, depends on type
Definition: pod/pod.h:222
spa_pod_float::value
float value
Definition: pod/pod.h:82
spa_pod_pointer::body
struct spa_pod_pointer_body body
Definition: pod/pod.h:188
spa_pod_choice_body::type
uint32_t type
type of choice, one of enum spa_choice_type
Definition: pod/pod.h:149
spa_pod_float::_padding
int32_t _padding
Definition: pod/pod.h:83
spa_pod_object::pod
struct spa_pod pod
Definition: pod/pod.h:176
spa_pod_fd::pod
struct spa_pod pod
Definition: pod/pod.h:192
spa_pod_sequence
a sequence of timed controls
Definition: pod/pod.h:233
SPA_CHOICE_None
@ SPA_CHOICE_None
no choice, first value is current
Definition: pod/pod.h:141
spa_pod_choice::pod
struct spa_pod pod
Definition: pod/pod.h:157
spa_pod::type
uint32_t type
Definition: pod/pod.h:52
spa_pod_fd::value
int64_t value
Definition: pod/pod.h:193
spa_pod_int::value
int32_t value
Definition: pod/pod.h:71
SPA_CHOICE_Step
@ SPA_CHOICE_Step
range with step: default, min, max, step
Definition: pod/pod.h:143
spa_pod_bytes
Definition: pod/pod.h:96
spa_pod_int::_padding
int32_t _padding
Definition: pod/pod.h:72
defs.h
spa_pod_bool::value
int32_t value
Definition: pod/pod.h:59
spa_pod_bool::_padding
int32_t _padding
Definition: pod/pod.h:60
spa_pod_struct
Definition: pod/pod.h:161
spa_pod_double::pod
struct spa_pod pod
Definition: pod/pod.h:87
type.h
spa_pod_choice_body::flags
uint32_t flags
extra flags
Definition: pod/pod.h:150
spa_pod_long
Definition: pod/pod.h:75
spa_pod_control::offset
uint32_t offset
media offset
Definition: pod/pod.h:220
spa_pod_pointer_body::_padding
uint32_t _padding
Definition: pod/pod.h:182
spa_pod_array_body::child
struct spa_pod child
Definition: pod/pod.h:123
spa_pod_fraction
Definition: pod/pod.h:106
spa_pod_string::pod
struct spa_pod pod
Definition: pod/pod.h:92