PipeWire 0.3.38
core.h
Go to the documentation of this file.
1/* PipeWire
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 PIPEWIRE_CORE_H
26#define PIPEWIRE_CORE_H
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
32#include <stdarg.h>
33#include <errno.h>
34
35#include <spa/utils/hook.h>
36
54#define PW_TYPE_INTERFACE_Core PW_TYPE_INFO_INTERFACE_BASE "Core"
55#define PW_TYPE_INTERFACE_Registry PW_TYPE_INFO_INTERFACE_BASE "Registry"
56
57#define PW_VERSION_CORE 3
58struct pw_core;
59#define PW_VERSION_REGISTRY 3
60struct pw_registry;
61
63#define PW_DEFAULT_REMOTE "pipewire-0"
64
66#define PW_ID_CORE 0
67
68/* invalid ID that matches any object when used for permissions */
69#define PW_ID_ANY (uint32_t)(0xffffffff)
70
74 uint32_t id;
75 uint32_t cookie;
76 const char *user_name;
77 const char *host_name;
78 const char *version;
79 const char *name;
80#define PW_CORE_CHANGE_MASK_PROPS (1 << 0)
81#define PW_CORE_CHANGE_MASK_ALL ((1 << 1)-1)
82 uint64_t change_mask;
83 struct spa_dict *props;
84};
85
86#include <pipewire/context.h>
87#include <pipewire/properties.h>
88#include <pipewire/proxy.h>
89
91struct pw_core_info *
93 const struct pw_core_info *update);
95struct pw_core_info *
97 const struct pw_core_info *update, bool reset);
99void pw_core_info_free(struct pw_core_info *info);
100
103#define PW_CORE_EVENT_INFO 0
104#define PW_CORE_EVENT_DONE 1
105#define PW_CORE_EVENT_PING 2
106#define PW_CORE_EVENT_ERROR 3
107#define PW_CORE_EVENT_REMOVE_ID 4
108#define PW_CORE_EVENT_BOUND_ID 5
109#define PW_CORE_EVENT_ADD_MEM 6
110#define PW_CORE_EVENT_REMOVE_MEM 7
111#define PW_CORE_EVENT_NUM 8
112
118#define PW_VERSION_CORE_EVENTS 0
119 uint32_t version;
120
129 void (*info) (void *object, const struct pw_core_info *info);
138 void (*done) (void *object, uint32_t id, int seq);
139
145 void (*ping) (void *object, uint32_t id, int seq);
146
164 void (*error) (void *object, uint32_t id, int seq, int res, const char *message);
176 void (*remove_id) (void *object, uint32_t id);
177
188 void (*bound_id) (void *object, uint32_t id, uint32_t global_id);
189
204 void (*add_mem) (void *object, uint32_t id, uint32_t type, int fd, uint32_t flags);
205
211 void (*remove_mem) (void *object, uint32_t id);
212};
213
214#define PW_CORE_METHOD_ADD_LISTENER 0
215#define PW_CORE_METHOD_HELLO 1
216#define PW_CORE_METHOD_SYNC 2
217#define PW_CORE_METHOD_PONG 3
218#define PW_CORE_METHOD_ERROR 4
219#define PW_CORE_METHOD_GET_REGISTRY 5
220#define PW_CORE_METHOD_CREATE_OBJECT 6
221#define PW_CORE_METHOD_DESTROY 7
222#define PW_CORE_METHOD_NUM 8
223
233#define PW_VERSION_CORE_METHODS 0
234 uint32_t version;
235
236 int (*add_listener) (void *object,
237 struct spa_hook *listener,
238 const struct pw_core_events *events,
239 void *data);
245 int (*hello) (void *object, uint32_t version);
257 int (*sync) (void *object, uint32_t id, int seq);
265 int (*pong) (void *object, uint32_t id, int seq);
282 int (*error) (void *object, uint32_t id, int seq, int res, const char *message);
291 struct pw_registry * (*get_registry) (void *object, uint32_t version,
292 size_t user_data_size);
293
303 void * (*create_object) (void *object,
304 const char *factory_name,
305 const char *type,
306 uint32_t version,
307 const struct spa_dict *props,
308 size_t user_data_size);
316 int (*destroy) (void *object, void *proxy);
317};
318
319#define pw_core_method(o,method,version,...) \
320({ \
321 int _res = -ENOTSUP; \
322 spa_interface_call_res((struct spa_interface*)o, \
323 struct pw_core_methods, _res, \
324 method, version, ##__VA_ARGS__); \
325 _res; \
326})
327
328#define pw_core_add_listener(c,...) pw_core_method(c,add_listener,0,__VA_ARGS__)
329#define pw_core_hello(c,...) pw_core_method(c,hello,0,__VA_ARGS__)
330#define pw_core_sync(c,...) pw_core_method(c,sync,0,__VA_ARGS__)
331#define pw_core_pong(c,...) pw_core_method(c,pong,0,__VA_ARGS__)
332#define pw_core_error(c,...) pw_core_method(c,error,0,__VA_ARGS__)
333
334
335static inline
336SPA_PRINTF_FUNC(5, 0) int
337pw_core_errorv(struct pw_core *core, uint32_t id, int seq,
338 int res, const char *message, va_list args)
339{
340 char buffer[1024];
341 vsnprintf(buffer, sizeof(buffer), message, args);
342 buffer[1023] = '\0';
343 return pw_core_error(core, id, seq, res, buffer);
344}
345
346static inline
347SPA_PRINTF_FUNC(5, 6) int
348pw_core_errorf(struct pw_core *core, uint32_t id, int seq,
349 int res, const char *message, ...)
350{
351 va_list args;
352 int r;
353 va_start(args, message);
354 r = pw_core_errorv(core, id, seq, res, message, args);
355 va_end(args);
356 return r;
357}
358
359static inline struct pw_registry *
360pw_core_get_registry(struct pw_core *core, uint32_t version, size_t user_data_size)
361{
362 struct pw_registry *res = NULL;
364 struct pw_core_methods, res,
365 get_registry, 0, version, user_data_size);
366 return res;
367}
368
369static inline void *
370pw_core_create_object(struct pw_core *core,
371 const char *factory_name,
372 const char *type,
373 uint32_t version,
374 const struct spa_dict *props,
375 size_t user_data_size)
376{
377 void *res = NULL;
379 struct pw_core_methods, res,
380 create_object, 0, factory_name,
381 type, version, props, user_data_size);
382 return res;
383}
384
385#define pw_core_destroy(c,...) pw_core_method(c,destroy,0,__VA_ARGS__)
386
426#define PW_REGISTRY_EVENT_GLOBAL 0
427#define PW_REGISTRY_EVENT_GLOBAL_REMOVE 1
428#define PW_REGISTRY_EVENT_NUM 2
429
432#define PW_VERSION_REGISTRY_EVENTS 0
433 uint32_t version;
446 void (*global) (void *object, uint32_t id,
447 uint32_t permissions, const char *type, uint32_t version,
448 const struct spa_dict *props);
458 void (*global_remove) (void *object, uint32_t id);
459};
460
461#define PW_REGISTRY_METHOD_ADD_LISTENER 0
462#define PW_REGISTRY_METHOD_BIND 1
463#define PW_REGISTRY_METHOD_DESTROY 2
464#define PW_REGISTRY_METHOD_NUM 3
465
468#define PW_VERSION_REGISTRY_METHODS 0
469 uint32_t version;
470
471 int (*add_listener) (void *object,
472 struct spa_hook *listener,
473 const struct pw_registry_events *events,
474 void *data);
487 void * (*bind) (void *object, uint32_t id, const char *type, uint32_t version,
488 size_t use_data_size);
489
497 int (*destroy) (void *object, uint32_t id);
498};
499
500#define pw_registry_method(o,method,version,...) \
501({ \
502 int _res = -ENOTSUP; \
503 spa_interface_call_res((struct spa_interface*)o, \
504 struct pw_registry_methods, _res, \
505 method, version, ##__VA_ARGS__); \
506 _res; \
507})
508
510#define pw_registry_add_listener(p,...) pw_registry_method(p,add_listener,0,__VA_ARGS__)
511
512static inline void *
513pw_registry_bind(struct pw_registry *registry,
514 uint32_t id, const char *type, uint32_t version,
515 size_t user_data_size)
516{
517 void *res = NULL;
519 struct pw_registry_methods, res,
520 bind, 0, id, type, version, user_data_size);
521 return res;
522}
523
524#define pw_registry_destroy(p,...) pw_registry_method(p,destroy,0,__VA_ARGS__)
525
545struct pw_core *
546pw_context_connect(struct pw_context *context,
547 struct pw_properties *properties,
548 size_t user_data_size);
549
560struct pw_core *
561pw_context_connect_fd(struct pw_context *context,
562 int fd,
563 struct pw_properties *properties,
564 size_t user_data_size);
565
574struct pw_core *
575pw_context_connect_self(struct pw_context *context,
576 struct pw_properties *properties,
577 size_t user_data_size);
578
581int pw_core_steal_fd(struct pw_core *core);
582
585int pw_core_set_paused(struct pw_core *core, bool paused);
586
588int pw_core_disconnect(struct pw_core *core);
589
592void *pw_core_get_user_data(struct pw_core *core);
593
596struct pw_client * pw_core_get_client(struct pw_core *core);
597
599struct pw_context * pw_core_get_context(struct pw_core *core);
600
602const struct pw_properties *pw_core_get_properties(struct pw_core *core);
603
607int pw_core_update_properties(struct pw_core *core, const struct spa_dict *dict);
608
610struct pw_mempool * pw_core_get_mempool(struct pw_core *core);
611
613struct pw_proxy *pw_core_find_proxy(struct pw_core *core, uint32_t id);
614
616struct pw_proxy *pw_core_export(struct pw_core *core,
617 const char *type,
618 const struct spa_dict *props,
619 void *object,
620 size_t user_data_size );
621
626#ifdef __cplusplus
627}
628#endif
629
630#endif /* PIPEWIRE_CORE_H */
struct pw_context * pw_core_get_context(struct pw_core *core)
Get the context object used to created this core.
Definition: core.c:132
struct pw_proxy * pw_core_find_proxy(struct pw_core *core, uint32_t id)
Get the proxy with the given id.
Definition: core.c:269
#define pw_core_error(c,...)
Definition: core.h:332
struct pw_core * pw_context_connect(struct pw_context *context, struct pw_properties *properties, size_t user_data_size)
Connect to a PipeWire instance.
Definition: core.c:402
struct pw_mempool * pw_core_get_mempool(struct pw_core *core)
Get the core mempool object.
Definition: core.c:483
const struct pw_properties * pw_core_get_properties(struct pw_core *core)
Get properties from the core.
Definition: core.c:138
struct pw_core * pw_context_connect_self(struct pw_context *context, struct pw_properties *properties, size_t user_data_size)
Connect to a given PipeWire instance.
Definition: core.c:454
struct pw_client * pw_core_get_client(struct pw_core *core)
Get the client proxy of the connected core.
Definition: core.c:263
void * pw_core_get_user_data(struct pw_core *core)
Get the user_data.
Definition: core.c:162
int pw_core_update_properties(struct pw_core *core, const struct spa_dict *dict)
Update the core properties.
Definition: core.c:144
struct pw_proxy * pw_core_export(struct pw_core *core, const char *type, const struct spa_dict *props, void *object, size_t user_data_size)
Export an object into the PipeWire instance associated with core.
Definition: core.c:275
int pw_core_disconnect(struct pw_core *core)
disconnect and destroy a core
Definition: core.c:489
int pw_core_steal_fd(struct pw_core *core)
Steal the fd of the core connection or < 0 on error.
Definition: core.c:468
int pw_core_set_paused(struct pw_core *core, bool paused)
Pause or resume the core.
Definition: core.c:476
void pw_core_info_free(struct pw_core_info *info)
Free a pw_core_info
Definition: introspect.c:165
struct pw_core * pw_context_connect_fd(struct pw_context *context, int fd, struct pw_properties *properties, size_t user_data_size)
Connect to a PipeWire instance on the given socket.
Definition: core.c:429
struct pw_core_info * pw_core_info_merge(struct pw_core_info *info, const struct pw_core_info *update, bool reset)
Update an existing pw_core_info with update.
Definition: introspect.c:127
struct pw_core_info * pw_core_info_update(struct pw_core_info *info, const struct pw_core_info *update)
Update an existing pw_core_info with update with reset.
Definition: introspect.c:158
#define spa_interface_call_res(iface, method_type, res, method, vers,...)
Invoke method named method in the callbacks on the given interface object.
Definition: hook.h:226
#define SPA_PRINTF_FUNC(fmt, arg1)
Definition: defs.h:211
const char * props
Definition: media-session.c:2397
Definition: filter.c:59
user data to add to an object
Definition: filter.c:75
Core events.
Definition: core.h:117
void(* error)(void *object, uint32_t id, int seq, int res, const char *message)
Fatal error event.
Definition: core.h:164
void(* remove_mem)(void *object, uint32_t id)
Remove memory for a client.
Definition: core.h:211
void(* done)(void *object, uint32_t id, int seq)
Emit a done event.
Definition: core.h:138
uint32_t version
Definition: core.h:119
void(* remove_id)(void *object, uint32_t id)
Remove an object ID.
Definition: core.h:176
void(* info)(void *object, const struct pw_core_info *info)
Notify new core info.
Definition: core.h:129
void(* ping)(void *object, uint32_t id, int seq)
Emit a ping event.
Definition: core.h:145
void(* bound_id)(void *object, uint32_t id, uint32_t global_id)
Notify an object binding.
Definition: core.h:188
void(* add_mem)(void *object, uint32_t id, uint32_t type, int fd, uint32_t flags)
Add memory for a client.
Definition: core.h:204
The core information.
Definition: core.h:73
struct spa_dict * props
extra properties
Definition: core.h:83
uint64_t change_mask
bitfield of changed fields since last call
Definition: core.h:82
const char * version
version of the core
Definition: core.h:78
uint32_t cookie
a random cookie for identifying this instance of PipeWire
Definition: core.h:75
uint32_t id
id of the global
Definition: core.h:74
const char * user_name
name of the user that started the core
Definition: core.h:76
const char * host_name
name of the machine the core is running on
Definition: core.h:77
const char * name
name of the core
Definition: core.h:79
Core methods.
Definition: core.h:232
int(* add_listener)(void *object, struct spa_hook *listener, const struct pw_core_events *events, void *data)
Definition: core.h:236
int(* pong)(void *object, uint32_t id, int seq)
Reply to a server ping event.
Definition: core.h:265
int(* destroy)(void *object, void *proxy)
Destroy an resource.
Definition: core.h:316
int(* hello)(void *object, uint32_t version)
Start a conversation with the server.
Definition: core.h:245
int(* error)(void *object, uint32_t id, int seq, int res, const char *message)
Fatal error event.
Definition: core.h:282
uint32_t version
Definition: core.h:234
A memory pool is a collection of pw_memblocks.
Definition: src/pipewire/mem.h:72
Definition: properties.h:49
struct spa_dict dict
dictionary of key/values
Definition: properties.h:50
Registry events.
Definition: core.h:431
void(* global_remove)(void *object, uint32_t id)
Notify of a global object removal.
Definition: core.h:458
uint32_t version
Definition: core.h:433
void(* global)(void *object, uint32_t id, uint32_t permissions, const char *type, uint32_t version, const struct spa_dict *props)
Notify of a new global object.
Definition: core.h:446
Registry methods.
Definition: core.h:467
uint32_t version
Definition: core.h:469
int(* add_listener)(void *object, struct spa_hook *listener, const struct pw_registry_events *events, void *data)
Definition: core.h:471
int(* destroy)(void *object, uint32_t id)
Attempt to destroy a global object.
Definition: core.h:497
Definition: pipewire.c:79
Definition: utils/dict.h:48
A hook, contains the structure with functions and the data passed to the functions.
Definition: hook.h:313
Definition: hook.h:149
Definition: media-session.c:123