Go to the documentation of this file.
25 #ifndef PIPEWIRE_CORE_H
26 #define PIPEWIRE_CORE_H
35 #include <spa/utils/hook.h>
37 #define PW_TYPE_INTERFACE_Core PW_TYPE_INFO_INTERFACE_BASE "Core"
38 #define PW_TYPE_INTERFACE_Registry PW_TYPE_INFO_INTERFACE_BASE "Registry"
40 #define PW_VERSION_CORE 3
42 #define PW_VERSION_REGISTRY 3
46 #define PW_DEFAULT_REMOTE "pipewire-0"
52 #define PW_ID_ANY (uint32_t)(0xffffffff)
62 #define PW_CORE_CHANGE_MASK_PROPS (1 << 0)
63 #define PW_CORE_CHANGE_MASK_ALL ((1 << 1)-1)
91 #define PW_CORE_EVENT_INFO 0
92 #define PW_CORE_EVENT_DONE 1
93 #define PW_CORE_EVENT_PING 2
94 #define PW_CORE_EVENT_ERROR 3
95 #define PW_CORE_EVENT_REMOVE_ID 4
96 #define PW_CORE_EVENT_BOUND_ID 5
97 #define PW_CORE_EVENT_ADD_MEM 6
98 #define PW_CORE_EVENT_REMOVE_MEM 7
99 #define PW_CORE_EVENT_NUM 8
106 #define PW_VERSION_CORE_EVENTS 0
176 void (*
bound_id) (
void *object, uint32_t
id, uint32_t global_id);
192 void (*
add_mem) (
void *object, uint32_t
id, uint32_t type,
int fd, uint32_t flags);
202 #define PW_CORE_METHOD_ADD_LISTENER 0
203 #define PW_CORE_METHOD_HELLO 1
204 #define PW_CORE_METHOD_SYNC 2
205 #define PW_CORE_METHOD_PONG 3
206 #define PW_CORE_METHOD_ERROR 4
207 #define PW_CORE_METHOD_GET_REGISTRY 5
208 #define PW_CORE_METHOD_CREATE_OBJECT 6
209 #define PW_CORE_METHOD_DESTROY 7
210 #define PW_CORE_METHOD_NUM 8
221 #define PW_VERSION_CORE_METHODS 0
225 struct spa_hook *listener,
279 struct pw_registry * (*get_registry) (
void *object, uint32_t
version,
280 size_t user_data_size);
291 void * (*create_object) (
void *object,
292 const char *factory_name,
295 const struct spa_dict *props,
296 size_t user_data_size);
307 #define pw_core_method(o,method,version,...) \
309 int _res = -ENOTSUP; \
310 spa_interface_call_res((struct spa_interface*)o, \
311 struct pw_core_methods, _res, \
312 method, version, ##__VA_ARGS__); \
316 #define pw_core_add_listener(c,...) pw_core_method(c,add_listener,0,__VA_ARGS__)
317 #define pw_core_hello(c,...) pw_core_method(c,hello,0,__VA_ARGS__)
318 #define pw_core_sync(c,...) pw_core_method(c,sync,0,__VA_ARGS__)
319 #define pw_core_pong(c,...) pw_core_method(c,pong,0,__VA_ARGS__)
320 #define pw_core_error(c,...) pw_core_method(c,error,0,__VA_ARGS__)
324 SPA_PRINTF_FUNC(5, 0) int
325 pw_core_errorv(struct pw_core *core, uint32_t
id,
int seq,
335 SPA_PRINTF_FUNC(5, 6) int
336 pw_core_errorf(struct pw_core *core, uint32_t
id,
int seq,
347 static inline struct pw_registry *
348 pw_core_get_registry(
struct pw_core *core, uint32_t version,
size_t user_data_size)
350 struct pw_registry *
res = NULL;
351 spa_interface_call_res((
struct spa_interface*)core,
353 get_registry, 0, version, user_data_size);
358 pw_core_create_object(
struct pw_core *core,
359 const char *factory_name,
362 const struct spa_dict *props,
363 size_t user_data_size)
366 spa_interface_call_res((
struct spa_interface*)core,
368 create_object, 0, factory_name,
369 type, version, props, user_data_size);
373 #define pw_core_destroy(c,...) pw_core_method(c,destroy,0,__VA_ARGS__)
407 #define PW_REGISTRY_EVENT_GLOBAL 0
408 #define PW_REGISTRY_EVENT_GLOBAL_REMOVE 1
409 #define PW_REGISTRY_EVENT_NUM 2
413 #define PW_VERSION_REGISTRY_EVENTS 0
428 uint32_t permissions,
const char *type, uint32_t
version,
429 const struct spa_dict *props);
442 #define PW_REGISTRY_METHOD_ADD_LISTENER 0
443 #define PW_REGISTRY_METHOD_BIND 1
444 #define PW_REGISTRY_METHOD_DESTROY 2
445 #define PW_REGISTRY_METHOD_NUM 3
449 #define PW_VERSION_REGISTRY_METHODS 0
453 struct spa_hook *listener,
468 void * (*bind) (
void *object, uint32_t
id,
const char *type, uint32_t
version,
469 size_t use_data_size);
481 #define pw_registry_method(o,method,version,...) \
483 int _res = -ENOTSUP; \
484 spa_interface_call_res((struct spa_interface*)o, \
485 struct pw_registry_methods, _res, \
486 method, version, ##__VA_ARGS__); \
491 #define pw_registry_add_listener(p,...) pw_registry_method(p,add_listener,0,__VA_ARGS__)
494 pw_registry_bind(
struct pw_registry *
registry,
495 uint32_t
id,
const char *type, uint32_t
version,
496 size_t user_data_size)
499 spa_interface_call_res((
struct spa_interface*)
registry,
501 bind, 0,
id, type,
version, user_data_size);
505 #define pw_registry_destroy(p,...) pw_registry_method(p,destroy,0,__VA_ARGS__)
515 size_t user_data_size );
526 size_t user_data_size );
534 size_t user_data_size );
575 const struct spa_dict *props,
577 size_t user_data_size );
static uint32_t int int res
Definition: core.h:326
#define PW_VERSION_CLIENT
Definition: client.h:40
struct pw_mempool * pool
owner pool
Definition: mem.h:69
void(* remove_mem)(void *object, uint32_t id)
Remove memory for a client.
Definition: core.h:199
SPA_EXPORT struct pw_client * pw_core_get_client(struct pw_core *core)
Get the client proxy of the connected core.
Definition: core.c:265
static uint32_t id
Definition: core.h:325
#define PW_KEY_REMOTE_NAME
The name of the remote to connect to, default pipewire-0, overwritten by env(PIPEWIRE_REMOTE)
Definition: keys.h:87
SPA_EXPORT struct pw_core * pw_context_connect_fd(struct pw_context *context, int fd, struct pw_properties *properties, size_t user_data_size)
Definition: core.c:432
data for registering export functions
Definition: context.h:165
static void * pw_map_lookup(struct pw_map *map, uint32_t id)
Find an item in the map.
Definition: map.h:169
const char * type
Definition: context.h:167
uint32_t version
Definition: core.h:414
uint32_t id
unique id
Definition: mem.h:70
PipeWire filter object class.
#define pw_log_error(...)
struct pw_protocol * pw_context_find_protocol(struct pw_context *context, const char *name)
Definition: protocol.c:178
The core information.
Definition: core.h:55
#define pw_protocol_new_client(p,...)
Definition: protocol.h:112
void pw_mempool_destroy(struct pw_mempool *pool)
Clear and destroy a pool.
Definition: mem.c:170
int(* destroy)(void *object, uint32_t id)
Attempt to destroy a global object.
Definition: core.h:478
void(* add_mem)(void *object, uint32_t id, uint32_t type, int fd, uint32_t flags)
Add memory for a client.
Definition: core.h:192
#define pw_client_update_properties(c,...)
Definition: client.h:163
static void pw_map_init(struct pw_map *map, size_t size, size_t extend)
Initialize a map.
Definition: map.h:76
int(* hello)(void *object, uint32_t version)
Start a conversation with the server.
Definition: core.h:233
void(* error)(void *object, uint32_t id, int seq, int res, const char *message)
Fatal error event.
Definition: core.h:152
Manages protocols and their implementation.
struct pw_context * pw_core_get_context(struct pw_core *core)
Get the context object used to created this core.
Definition: core.c:134
uint32_t version
Definition: core.h:107
int pw_core_disconnect(struct pw_core *core)
disconnect and destroy a core
Definition: core.c:492
uint32_t flags
flags for the memory block on of enum pw_memblock_flags
Definition: mem.h:72
#define PW_VERSION_CORE
Definition: core.h:40
int pw_proxy_set_bound_id(struct pw_proxy *proxy, uint32_t global_id)
Set the global id this proxy is bound to.
Definition: proxy.c:160
SPA_EXPORT void pw_proxy_destroy(struct pw_proxy *proxy)
Destroy a proxy object.
Definition: proxy.c:232
struct pw_mempool * pw_core_get_mempool(struct pw_core *core)
Get the core mempool object.
Definition: core.c:486
#define pw_core_pong(c,...)
Definition: core.h:319
struct pw_core_info * pw_core_info_update(struct pw_core_info *info, const struct pw_core_info *update)
Update and existing pw_core_info with update.
Definition: introspect.c:129
const char * user_name
name of the user that started the core
Definition: core.h:58
Proxy events, use pw_proxy_add_listener.
Definition: proxy.h:106
#define pw_protocol_client_connect(c, p, cb, d)
Definition: protocol.h:60
SPA_EXPORT struct pw_proxy * pw_proxy_new(struct pw_proxy *factory, const char *type, uint32_t version, size_t user_data_size)
Create a proxy object with a given id and type.
Definition: proxy.c:91
const char * version
version of the core
Definition: core.h:60
static uint32_t int int const char int r
Definition: core.h:338
const struct pw_export_type * pw_context_find_export_type(struct pw_context *context, const char *type)
find information about registered export type
void(* bound_id)(void *object, uint32_t id, uint32_t global_id)
Notify an object binding.
Definition: core.h:176
SPA_EXPORT int pw_core_update_properties(struct pw_core *core, const struct spa_dict *dict)
Update the core properties.
Definition: core.c:146
struct spa_dict dict
dictionary of key/values
Definition: properties.h:46
SPA_EXPORT int pw_core_set_paused(struct pw_core *core, bool paused)
Pause or resume the core.
Definition: core.c:479
const char * host_name
name of the machine the core is running on
Definition: core.h:59
int pw_core_set_paused(struct pw_core *core, bool paused)
Pause or resume the core.
Definition: core.c:479
SPA_EXPORT struct pw_proxy * pw_core_find_proxy(struct pw_core *core, uint32_t id)
Get the proxy with the given id.
Definition: core.c:271
static int pw_map_for_each(struct pw_map *map, int(*func)(void *item_data, void *data), void *data)
Iterate all map items.
Definition: map.h:188
void pw_proxy_remove(struct pw_proxy *proxy)
called when cleaning up or when the server removed the resource.
Definition: proxy.c:268
Registry events.
Definition: core.h:412
int(* add_listener)(void *object, struct spa_hook *listener, const struct pw_core_events *events, void *data)
Definition: core.h:224
#define PW_VERSION_PROXY_EVENTS
Definition: proxy.h:107
int pw_core_update_properties(struct pw_core *core, const struct spa_dict *dict)
Update the core properties.
Definition: core.c:146
int(* error)(void *object, uint32_t id, int seq, int res, const char *message)
Fatal error event.
Definition: core.h:270
int(* pong)(void *object, uint32_t id, int seq)
Reply to a server ping event.
Definition: core.h:253
int(* sync)(void *object, uint32_t id, int seq)
Do server roundtrip.
Definition: core.h:245
void * pw_core_get_user_data(struct pw_core *core)
Get the user_data.
Definition: core.c:164
#define pw_core_error(c,...)
Definition: core.h:320
int fd
fd
Definition: mem.h:74
uint64_t change_mask
bitfield of changed fields since last call
Definition: core.h:64
int(* add_listener)(void *object, struct spa_hook *listener, const struct pw_registry_events *events, void *data)
Definition: core.h:452
#define pw_protocol_client_disconnect(c)
Definition: protocol.h:63
void(* info)(void *object, const struct pw_core_info *info)
Notify new core info.
Definition: core.h:117
static uint32_t int int const char * message
Definition: core.h:326
#define pw_log_debug(...)
struct spa_dict * props
extra properties
Definition: core.h:65
SPA_EXPORT struct pw_core * pw_context_connect_self(struct pw_context *context, struct pw_properties *properties, size_t user_data_size)
Definition: core.c:457
Represents an object on the client side.
struct pw_memblock * pw_mempool_import(struct pw_mempool *pool, enum pw_memblock_flags flags, uint32_t type, int fd)
Import an fd into the pool.
Definition: mem.c:561
SPA_EXPORT int pw_core_steal_fd(struct pw_core *core)
Steal the fd of the core connection or < 0 on error.
Definition: core.c:471
#define PW_TYPE_INTERFACE_Core
Definition: core.h:37
int(* destroy)(void *object, void *proxy)
Destroy an resource.
Definition: core.h:304
SPA_EXPORT int pw_properties_update(struct pw_properties *props, const struct spa_dict *dict)
Update properties.
Definition: properties.c:263
#define pw_core_add_listener(c,...)
Definition: core.h:316
#define pw_protocol_client_set_paused(c, p)
Definition: protocol.h:65
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:277
Core methods.
Definition: core.h:220
struct pw_proxy * pw_core_find_proxy(struct pw_core *core, uint32_t id)
Get the proxy with the given id.
Definition: core.c:271
static void pw_map_clear(struct pw_map *map)
Clear a map.
Definition: map.h:87
void pw_core_info_free(struct pw_core_info *info)
Free a pw_core_info.
Definition: introspect.c:158
void(* global_remove)(void *object, uint32_t id)
Notify of a global object removal.
Definition: core.h:439
int pw_core_steal_fd(struct pw_core *core)
Steal the fd of the core connection or < 0 on error.
Definition: core.c:471
int pw_proxy_errorf(struct pw_proxy *proxy, int res, const char *error,...) SPA_PRINTF_FUNC(3
const SPA_EXPORT char * pw_properties_get(const struct pw_properties *properties, const char *key)
Get a property.
Definition: properties.c:456
#define NAME
Definition: core.c:40
SPA_EXPORT struct pw_context * pw_core_get_context(struct pw_core *core)
Get the context object used to created this core.
Definition: core.c:134
static uint32_t int int const char va_list args
Definition: core.h:327
#define PW_VERSION_CORE_EVENTS
Definition: core.h:106
uint32_t version
Definition: core.h:222
SPA_EXPORT int pw_properties_set(struct pw_properties *properties, const char *key, const char *value)
Set a property value.
Definition: properties.c:400
vsnprintf(buffer, sizeof(buffer), message, args)
#define pw_core_hello(c,...)
Definition: core.h:317
#define pw_log_trace(...)
const struct pw_properties * pw_core_get_properties(struct pw_core *core)
Get properties from the core.
Definition: core.c:140
#define pw_protocol_client_steal_fd(c)
Definition: protocol.h:62
struct pw_proxy *(* func)(struct pw_core *core, const char *type, const struct spa_dict *props, void *object, size_t user_data_size)
Definition: context.h:168
void pw_proxy_add_listener(struct pw_proxy *proxy, struct spa_hook *listener, const struct pw_proxy_events *events, void *data)
Add an event listener to proxy.
Definition: proxy.c:197
int pw_stream_disconnect(struct pw_stream *stream)
Disconnect stream.
Definition: stream.c:1630
int pw_proxy_init(struct pw_proxy *proxy, const char *type, uint32_t version)
Definition: proxy.c:43
const char * name
name of the core
Definition: core.h:61
#define pw_protocol_client_connect_fd(c, fd, cl)
Definition: protocol.h:61
uint32_t cookie
a random cookie for identifying this instance of PipeWire
Definition: core.h:57
Definition: pipewire.c:66
#define PW_TYPE_INTERFACE_Client
Definition: client.h:38
struct pw_mempool * pw_mempool_new(struct pw_properties *props)
Create a new memory pool.
Definition: mem.c:133
SPA_EXPORT int pw_properties_add(struct pw_properties *props, const struct spa_dict *dict)
Add properties.
Definition: properties.c:286
SPA_EXPORT struct pw_mempool * pw_core_get_mempool(struct pw_core *core)
Get the core mempool object.
Definition: core.c:486
int pw_mempool_remove_id(struct pw_mempool *pool, uint32_t id)
Remove a memblock for given id.
Definition: mem.c:661
Registry methods.
Definition: core.h:448
void(* done)(void *object, uint32_t id, int seq)
Emit a done event.
Definition: core.h:126
void pw_stream_destroy(struct pw_stream *stream)
Destroy a stream.
Definition: stream.c:1276
SPA_EXPORT void * pw_core_get_user_data(struct pw_core *core)
Get the user_data.
Definition: core.c:164
void(* remove_id)(void *object, uint32_t id)
Remove an object ID.
Definition: core.h:164
void pw_filter_destroy(struct pw_filter *filter)
Destroy a filter.
Definition: filter.c:1098
SPA_EXPORT struct pw_properties * pw_properties_new(const char *key,...)
Make a new properties object.
Definition: properties.c:98
SPA_EXPORT const struct pw_properties * pw_core_get_properties(struct pw_core *core)
Get properties from the core.
Definition: core.c:140
static uint32_t int seq
Definition: core.h:325
PipeWire stream object class.
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:427
void(* ping)(void *object, uint32_t id, int seq)
Emit a ping event.
Definition: core.h:133
struct pw_client * pw_core_get_client(struct pw_core *core)
Get the client proxy of the connected core.
Definition: core.c:265
int pw_filter_disconnect(struct pw_filter *filter)
Disconnect filter.
Definition: filter.c:1293
uint32_t id
id of the global
Definition: core.h:56
uint32_t type
type of the fd, one of enum spa_data_type
Definition: mem.h:73
#define pw_protocol_client_destroy(c)
Definition: protocol.h:64
SPA_EXPORT struct pw_core * pw_context_connect(struct pw_context *context, struct pw_properties *properties, size_t user_data_size)
Definition: core.c:405
SPA_EXPORT 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:277
SPA_EXPORT int pw_core_disconnect(struct pw_core *core)
disconnect and destroy a core
Definition: core.c:492
A collection of key/value pairs.
Definition: properties.h:45
SPA_EXPORT void pw_properties_free(struct pw_properties *properties)
Free a properties object.
Definition: properties.c:335
#define PW_KEY_PROTOCOL
A collection of keys that are used to add extra information on objects.
Definition: keys.h:42
Core events.
Definition: core.h:105
uint32_t version
Definition: core.h:450