mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-05 15:08:48 +00:00
GstShmAllocator: Respect allocation params
Sponsored-by: Netflix Inc. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5328>
This commit is contained in:
parent
f57dabe65c
commit
5b4d37d6f2
1 changed files with 27 additions and 2 deletions
|
@ -58,7 +58,11 @@ gst_shm_allocator_alloc (GstAllocator * allocator, gsize size,
|
||||||
GstMemory *mem;
|
GstMemory *mem;
|
||||||
GstMapInfo info;
|
GstMapInfo info;
|
||||||
|
|
||||||
/* TODO: make use of the allocation params, if necessary */
|
/* See _sysmem_new_block() for details */
|
||||||
|
gsize maxsize = size + params->prefix + params->padding;
|
||||||
|
gsize align = params->align;
|
||||||
|
align |= gst_memory_alignment;
|
||||||
|
maxsize += align;
|
||||||
|
|
||||||
#ifdef HAVE_MEMFD_CREATE
|
#ifdef HAVE_MEMFD_CREATE
|
||||||
fd = memfd_create ("gst-shm", MFD_CLOEXEC | MFD_ALLOW_SEALING);
|
fd = memfd_create ("gst-shm", MFD_CLOEXEC | MFD_ALLOW_SEALING);
|
||||||
|
@ -84,7 +88,7 @@ gst_shm_allocator_alloc (GstAllocator * allocator, gsize size,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (ftruncate (fd, size) < 0) {
|
if (ftruncate (fd, maxsize) < 0) {
|
||||||
GST_ERROR_OBJECT (self, "ftruncate failed: %s", strerror (errno));
|
GST_ERROR_OBJECT (self, "ftruncate failed: %s", strerror (errno));
|
||||||
close (fd);
|
close (fd);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -104,6 +108,27 @@ gst_shm_allocator_alloc (GstAllocator * allocator, gsize size,
|
||||||
gst_memory_unref (mem);
|
gst_memory_unref (mem);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* See _sysmem_new_block() for details */
|
||||||
|
guint8 *data = info.data;
|
||||||
|
gsize aoffset;
|
||||||
|
if ((aoffset = ((guintptr) data & align))) {
|
||||||
|
aoffset = (align + 1) - aoffset;
|
||||||
|
data += aoffset;
|
||||||
|
maxsize -= aoffset;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (params->prefix && (params->flags & GST_MEMORY_FLAG_ZERO_PREFIXED))
|
||||||
|
memset (data, 0, params->prefix);
|
||||||
|
|
||||||
|
gsize padding = maxsize - (params->prefix + size);
|
||||||
|
if (padding && (params->flags & GST_MEMORY_FLAG_ZERO_PADDED))
|
||||||
|
memset (data + params->prefix + size, 0, padding);
|
||||||
|
|
||||||
|
mem->align = align;
|
||||||
|
mem->maxsize = maxsize;
|
||||||
|
mem->offset = params->prefix + aoffset;
|
||||||
|
|
||||||
gst_memory_unmap (mem, &info);
|
gst_memory_unmap (mem, &info);
|
||||||
|
|
||||||
#ifdef HAVE_MEMFD_CREATE
|
#ifdef HAVE_MEMFD_CREATE
|
||||||
|
|
Loading…
Reference in a new issue