Go to the documentation of this file.
25 #ifndef PIPEWIRE_CONTROL_H
26 #define PIPEWIRE_CONTROL_H
49 #define PW_VERSION_CONTROL_EVENTS 0
#define SPA_MAX(a, b)
Definition: defs.h:129
Definition: module-filter-chain.c:176
void pw_control_add_listener(struct pw_control *control, struct spa_hook *listener, const struct pw_control_events *events, void *data)
Add an event listener on the control.
Definition: control.c:138
spa_direction
Definition: defs.h:78
#define NAME
Definition: control.c:31
@ PW_MEMBLOCK_FLAG_READWRITE
Definition: src/pipewire/mem.h:53
int pw_control_remove_link(struct pw_control_link *link)
Definition: control.c:237
Port events, use pw_control_add_listener.
Definition: src/pipewire/control.h:48
user data to add to an object
Definition: filter.c:75
struct pw_memblock * pw_mempool_alloc(struct pw_mempool *pool, enum pw_memblock_flags flags, uint32_t type, size_t size)
Allocate a memory block from the pool.
Definition: mem.c:464
#define SPA_EXPORT
Definition: defs.h:208
struct port * output
Definition: module-filter-chain.c:182
@ SPA_DIRECTION_INPUT
Definition: defs.h:79
struct pw_control * pw_control_new(struct pw_context *context, struct pw_impl_port *port, uint32_t id, uint32_t size, size_t user_data_size)
Definition: control.c:40
void(* linked)(void *data, struct pw_control *other)
control is linked to another control
Definition: src/pipewire/control.h:59
void spa_hook_list_append(struct spa_hook_list *list, struct spa_hook *hook, const void *funcs, void *data)
Append a hook.
Definition: hook.h:316
void * ptr
mapped pointer
Definition: src/pipewire/mem.h:92
#define SPA_PTROFF(ptr_, offset_, type_)
Return the address (buffer + offset) as pointer of type.
Definition: defs.h:159
struct spa_node * node
Definition: buffers.c:45
@ SPA_IO_Control
area for control messages, struct spa_io_sequence
Definition: io.h:57
int pw_control_add_link(struct pw_control *control, uint32_t cmix, struct pw_control *other, uint32_t omix, struct pw_control_link *link)
Definition: control.c:166
#define SPA_CONTAINER_OF(p, t, m)
Definition: defs.h:170
#define spa_list_consume(pos, head, member)
Definition: list.h:96
#define spa_node_port_set_io(n,...)
Definition: build-12775836/doc/spa/node/node.h:660
struct port * input
Definition: module-filter-chain.c:183
void spa_list_remove(struct spa_list *elem)
Definition: list.h:69
#define SPA_RESULT_IS_OK(res)
Definition: result.h:44
@ PW_MEMBLOCK_FLAG_SEAL
seal the fd
Definition: src/pipewire/mem.h:48
void pw_control_destroy(struct pw_control *control)
Definition: control.c:94
uint32_t id
Definition: stream.c:87
A hook, contains the structure with functions and the data passed to the functions.
Definition: hook.h:295
struct spa_list link
Definition: stream.c:90
void(* destroy)(void *data)
The control is destroyed.
Definition: src/pipewire/control.h:53
@ PW_MEMBLOCK_FLAG_MAP
mmap the fd
Definition: src/pipewire/mem.h:49
struct pw_memmap * map
optional map when PW_MEMBLOCK_FLAG_MAP was given
Definition: src/pipewire/mem.h:86
void spa_list_init(struct spa_list *list)
Definition: list.h:44
@ SPA_IO_Notify
area for notify messages, struct spa_io_sequence
Definition: io.h:58
@ SPA_DIRECTION_OUTPUT
Definition: defs.h:80
struct pw_impl_port * pw_control_get_port(struct pw_control *control)
Get the control parent port or NULL when not set.
Definition: control.c:132
uint32_t port_id
Definition: buffers.c:47
uint32_t version
Definition: src/pipewire/control.h:50
#define spa_strerror(err)
Definition: result.h:51
#define SPA_SWAP(a, b)
Definition: defs.h:143
Memory block structure.
Definition: src/pipewire/mem.h:78
#define pw_log_debug(...)
Definition: src/pipewire/log.h:89
const struct spa_type_info spa_type_io[]
Definition: node/type-info.h:46
void(* free)(void *data)
The control is freed.
Definition: src/pipewire/control.h:56
#define spa_list_is_empty(l)
Definition: list.h:49
void(* unlinked)(void *data, struct pw_control *other)
control is unlinked from another control
Definition: src/pipewire/control.h:61
@ SPA_DATA_MemFd
generic fd, mmap to get to memory
Definition: buffer/buffer.h:49
struct pw_memblock * mem
Definition: control.c:36
#define pw_log_warn(...)
Definition: src/pipewire/log.h:87
struct pw_control this
Definition: control.c:34
void spa_hook_list_init(struct spa_hook_list *list)
Initialize a hook list to the empty list.
Definition: hook.h:305
enum spa_direction direction
Definition: buffers.c:46
void spa_hook_list_clean(struct spa_hook_list *list)
Remove all hooks from the list.
Definition: hook.h:344
const char * spa_debug_type_find_name(const struct spa_type_info *info, uint32_t type)
Definition: types.h:68
#define spa_list_append(list, item)
Definition: list.h:81