PipeWire  1.6.4
mem.h
Go to the documentation of this file.
1 /* PipeWire */
2 /* SPDX-FileCopyrightText: Copyright © 2018 Wim Taymans */
3 /* SPDX-License-Identifier: MIT */
4 
5 #ifndef PIPEWIRE_MEM_H
6 #define PIPEWIRE_MEM_H
7 
8 #include <pipewire/properties.h>
9 
10 struct spa_hook;
11 
12 #ifdef __cplusplus
13 extern "C" {
14 #endif
15 
16 #ifndef PW_API_MEM
17 #define PW_API_MEM static inline
18 #endif
19 
30 enum pw_memblock_flags {
32  PW_MEMBLOCK_FLAG_READABLE = (1 << 0),
33  PW_MEMBLOCK_FLAG_WRITABLE = (1 << 1),
34  PW_MEMBLOCK_FLAG_SEAL = (1 << 2),
35  PW_MEMBLOCK_FLAG_MAP = (1 << 3),
41 };
42 
45  PW_MEMMAP_FLAG_READ = (1 << 0),
46  PW_MEMMAP_FLAG_WRITE = (1 << 1),
47  PW_MEMMAP_FLAG_TWICE = (1 << 2),
50  PW_MEMMAP_FLAG_LOCKED = (1 << 4),
52 };
53 
54 struct pw_memchunk;
55 
59 struct pw_mempool {
60  struct pw_properties *props;
61 };
62 
65 struct pw_memblock {
66  struct pw_mempool *pool;
67  uint32_t id;
68  int ref;
69  uint32_t flags;
70  uint32_t type;
71  int fd;
72  uint32_t size;
73  struct pw_memmap *map;
74 };
75 
77 struct pw_memmap {
78  struct pw_memblock *block;
79  void *ptr;
80  uint32_t flags;
81  uint32_t offset;
82  uint32_t size;
83  uint32_t tag[5];
84 };
85 
87 #define PW_VERSION_MEMPOOL_EVENTS 0
88  uint32_t version;
89 
91  void (*destroy) (void *data);
92 
94  void (*added) (void *data, struct pw_memblock *block);
95 
97  void (*removed) (void *data, struct pw_memblock *block);
98 };
99 
101 struct pw_mempool *pw_mempool_new(struct pw_properties *props);
102 
104 void pw_mempool_add_listener(struct pw_mempool *pool,
105  struct spa_hook *listener,
106  const struct pw_mempool_events *events,
107  void *data);
108 
110 void pw_mempool_clear(struct pw_mempool *pool);
111 
113 void pw_mempool_destroy(struct pw_mempool *pool);
114 
115 
118  enum pw_memblock_flags flags, uint32_t type, size_t size);
119 
122  struct pw_memblock *mem);
123 
126  enum pw_memblock_flags flags, uint32_t type, int fd);
127 
129 void pw_memblock_free(struct pw_memblock *mem);
130 
132 PW_API_MEM void pw_memblock_unref(struct pw_memblock *mem)
133 {
134  if (--mem->ref == 0)
135  pw_memblock_free(mem);
136 }
137 
139 int pw_mempool_remove_id(struct pw_mempool *pool, uint32_t id);
140 
142 struct pw_memblock * pw_mempool_find_ptr(struct pw_mempool *pool, const void *ptr);
143 
145 struct pw_memblock * pw_mempool_find_id(struct pw_mempool *pool, uint32_t id);
146 
148 struct pw_memblock * pw_mempool_find_fd(struct pw_mempool *pool, int fd);
149 
150 
152 struct pw_memmap * pw_memblock_map(struct pw_memblock *block,
153  enum pw_memmap_flags flags, uint32_t offset, uint32_t size,
154  uint32_t tag[5]);
155 
157 struct pw_memmap * pw_mempool_map_id(struct pw_mempool *pool, uint32_t id,
158  enum pw_memmap_flags flags, uint32_t offset, uint32_t size,
159  uint32_t tag[5]);
160 
161 struct pw_memmap * pw_mempool_import_map(struct pw_mempool *pool,
162  struct pw_mempool *other, void *data, uint32_t size, uint32_t tag[5]);
163 
165 struct pw_memmap * pw_mempool_find_tag(struct pw_mempool *pool, uint32_t tag[5], size_t size);
166 
168 int pw_memmap_free(struct pw_memmap *map);
169 
170 
172 struct pw_map_range {
173  uint32_t start;
174  uint32_t offset;
175  uint32_t size;
176 };
177 
178 #define PW_MAP_RANGE_INIT (struct pw_map_range){ 0, }
179 
184  uint32_t offset, uint32_t size,
185  uint32_t page_size)
186 {
187  range->offset = SPA_ROUND_DOWN_N(offset, page_size);
188  range->start = offset - range->offset;
189  if (size > UINT32_MAX - range->start)
190  return -EOVERFLOW;
191  /* Check that rounding up to page_size won't overflow */
192  if (range->start + size > UINT32_MAX - (page_size - 1))
193  return -EOVERFLOW;
194  range->size = SPA_ROUND_UP_N(range->start + size, page_size);
195  return 0;
196 }
197 
202 #ifdef __cplusplus
203 }
204 #endif
205 
206 #endif /* PIPEWIRE_MEM_H */
struct pw_memmap * pw_memblock_map(struct pw_memblock *block, enum pw_memmap_flags flags, uint32_t offset, uint32_t size, uint32_t tag[5])
Map a region of a memory block.
Definition: mem.c:390
pw_memmap_flags
Definition: mem.h:49
int pw_memmap_free(struct pw_memmap *map)
Unmap a region.
Definition: mem.c:479
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:527
struct pw_memblock * pw_mempool_import_block(struct pw_mempool *pool, struct pw_memblock *mem)
Import a block from another pool.
Definition: mem.c:715
int pw_mempool_remove_id(struct pw_mempool *pool, uint32_t id)
Remove a memblock for given id.
Definition: mem.c:800
void pw_mempool_add_listener(struct pw_mempool *pool, struct spa_hook *listener, const struct pw_mempool_events *events, void *data)
Listen for events.
Definition: mem.c:212
struct pw_memblock * pw_mempool_find_ptr(struct pw_mempool *pool, const void *ptr)
Find memblock for given ptr.
Definition: mem.c:873
PW_API_MEM void pw_memblock_unref(struct pw_memblock *mem)
Unref a memblock.
Definition: mem.h:140
struct pw_memmap * pw_mempool_import_map(struct pw_mempool *pool, struct pw_mempool *other, void *data, uint32_t size, uint32_t tag[5])
Definition: mem.c:747
struct pw_memblock * pw_mempool_find_id(struct pw_mempool *pool, uint32_t id)
Find memblock for given id.
Definition: mem.c:892
void pw_mempool_clear(struct pw_mempool *pool)
Clear a pool.
Definition: mem.c:181
void pw_memblock_free(struct pw_memblock *mem)
Free a memblock regardless of the refcount and destroy all mappings.
Definition: mem.c:823
pw_memblock_flags
Flags passed to pw_mempool_alloc()
Definition: mem.h:36
struct pw_memmap * pw_mempool_map_id(struct pw_mempool *pool, uint32_t id, enum pw_memmap_flags flags, uint32_t offset, uint32_t size, uint32_t tag[5])
Map a region of a memory block with id.
Definition: mem.c:464
void pw_mempool_destroy(struct pw_mempool *pool)
Clear and destroy a pool.
Definition: mem.c:194
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:650
struct pw_memblock * pw_mempool_find_fd(struct pw_mempool *pool, int fd)
Find memblock for given fd.
Definition: mem.c:906
struct pw_mempool * pw_mempool_new(struct pw_properties *props)
Create a new memory pool.
Definition: mem.c:157
struct pw_memmap * pw_mempool_find_tag(struct pw_mempool *pool, uint32_t tag[5], size_t size)
find a map with the given tag
Definition: mem.c:918
PW_API_MEM int pw_map_range_init(struct pw_map_range *range, uint32_t offset, uint32_t size, uint32_t page_size)
Calculate parameters to mmap() memory into range so that size bytes at offset can be mapped with mmap...
Definition: mem.h:192
@ PW_MEMMAP_FLAG_LOCKED
lock the memory into RAM
Definition: mem.h:56
@ PW_MEMMAP_FLAG_READ
map in read mode
Definition: mem.h:51
@ PW_MEMMAP_FLAG_READWRITE
Definition: mem.h:57
@ PW_MEMMAP_FLAG_WRITE
map in write mode
Definition: mem.h:52
@ PW_MEMMAP_FLAG_NONE
Definition: mem.h:50
@ PW_MEMMAP_FLAG_TWICE
map the same area twice after each other, creating a circular ringbuffer
Definition: mem.h:53
@ PW_MEMMAP_FLAG_PRIVATE
writes will be private
Definition: mem.h:55
@ PW_MEMBLOCK_FLAG_READWRITE
Definition: mem.h:46
@ PW_MEMBLOCK_FLAG_MAP
mmap the fd
Definition: mem.h:41
@ PW_MEMBLOCK_FLAG_DONT_NOTIFY
don't notify events
Definition: mem.h:43
@ PW_MEMBLOCK_FLAG_READABLE
memory is readable
Definition: mem.h:38
@ PW_MEMBLOCK_FLAG_SEAL
seal the fd
Definition: mem.h:40
@ PW_MEMBLOCK_FLAG_WRITABLE
memory is writable
Definition: mem.h:39
@ PW_MEMBLOCK_FLAG_NONE
Definition: mem.h:37
@ PW_MEMBLOCK_FLAG_UNMAPPABLE
the fd can not be mmapped
Definition: mem.h:44
@ PW_MEMBLOCK_FLAG_DONT_CLOSE
don't close fd
Definition: mem.h:42
#define SPA_ROUND_UP_N(num, align)
Definition: defs.h:364
#define SPA_ROUND_DOWN_N(num, align)
Definition: defs.h:362
pipewire/properties.h
#define PW_API_MEM
Definition: mem.h:23
parameters to map a memory range
Definition: mem.h:180
uint32_t size
page aligned offset to map
Definition: mem.h:183
uint32_t offset
offset in first page with start of data
Definition: mem.h:182
Memory block structure.
Definition: mem.h:72
uint32_t id
unique id
Definition: mem.h:74
int fd
fd
Definition: mem.h:78
struct pw_mempool * pool
owner pool
Definition: mem.h:73
uint32_t flags
flags for the memory block on of enum pw_memblock_flags
Definition: mem.h:76
uint32_t size
size of memory
Definition: mem.h:79
uint32_t type
type of the fd, one of enum spa_data_type
Definition: mem.h:77
int ref
refcount
Definition: mem.h:75
struct pw_memmap * map
optional map when PW_MEMBLOCK_FLAG_MAP was given
Definition: mem.h:80
a mapped region of a pw_memblock
Definition: mem.h:84
uint32_t offset
offset in memblock
Definition: mem.h:88
void * ptr
mapped pointer
Definition: mem.h:86
uint32_t flags
flags for the mapping on of enum pw_memmap_flags
Definition: mem.h:87
uint32_t size
size in memblock
Definition: mem.h:89
struct pw_memblock * block
owner memblock
Definition: mem.h:85
uint32_t tag[5]
user tag
Definition: mem.h:90
Definition: mem.h:93
void(* removed)(void *data, struct pw_memblock *block)
a memory block is removed from the pool
Definition: mem.h:105
void(* destroy)(void *data)
the pool is destroyed
Definition: mem.h:99
void(* added)(void *data, struct pw_memblock *block)
a new memory block is added to the pool
Definition: mem.h:102
uint32_t version
Definition: mem.h:96
A memory pool is a collection of pw_memblocks.
Definition: mem.h:66
Definition: properties.h:39
A hook, contains the structure with functions and the data passed to the functions.
Definition: hook.h:427