2013-02-19 09:40:31 +00:00
|
|
|
/* GStreamer dmabuf allocator
|
|
|
|
* Copyright (C) 2013 Linaro SA
|
2013-02-18 14:18:38 +00:00
|
|
|
* Author: Benjamin Gaignard <benjamin.gaignard@linaro.org> for Linaro.
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Library General Public License for mordetails.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this library; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
2013-02-19 10:52:22 +00:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
|
|
|
|
2015-03-15 14:16:23 +00:00
|
|
|
#include "gstfdmemory.h"
|
2013-02-18 14:18:38 +00:00
|
|
|
#include "gstdmabuf.h"
|
|
|
|
|
2013-02-19 09:05:17 +00:00
|
|
|
/**
|
|
|
|
* SECTION:gstdmabuf
|
|
|
|
* @short_description: Memory wrapper for Linux dmabuf memory
|
|
|
|
* @see_also: #GstMemory
|
|
|
|
*
|
2013-02-19 09:40:31 +00:00
|
|
|
* Since: 1.2
|
2013-02-19 09:05:17 +00:00
|
|
|
*/
|
|
|
|
|
2013-09-19 14:33:29 +00:00
|
|
|
#ifdef HAVE_MMAP
|
2013-02-18 14:18:38 +00:00
|
|
|
#include <sys/mman.h>
|
|
|
|
#include <unistd.h>
|
2013-09-19 14:33:29 +00:00
|
|
|
#endif
|
2013-02-18 14:18:38 +00:00
|
|
|
|
|
|
|
GST_DEBUG_CATEGORY_STATIC (dmabuf_debug);
|
|
|
|
#define GST_CAT_DEFAULT dmabuf_debug
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
2015-03-18 14:12:03 +00:00
|
|
|
GstFdAllocator parent;
|
2013-03-30 11:08:06 +00:00
|
|
|
} GstDmaBufAllocator;
|
2013-02-18 14:18:38 +00:00
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
2015-03-18 14:12:03 +00:00
|
|
|
GstFdAllocatorClass parent_class;
|
2013-03-30 11:08:06 +00:00
|
|
|
} GstDmaBufAllocatorClass;
|
2013-02-18 14:18:38 +00:00
|
|
|
|
|
|
|
GType dmabuf_mem_allocator_get_type (void);
|
2015-03-18 14:12:03 +00:00
|
|
|
G_DEFINE_TYPE (GstDmaBufAllocator, dmabuf_mem_allocator, GST_TYPE_FD_ALLOCATOR);
|
2013-02-18 14:18:38 +00:00
|
|
|
|
|
|
|
#define GST_TYPE_DMABUF_ALLOCATOR (dmabuf_mem_allocator_get_type())
|
|
|
|
#define GST_IS_DMABUF_ALLOCATOR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GST_TYPE_DMABUF_ALLOCATOR))
|
|
|
|
|
|
|
|
static void
|
2013-03-30 11:08:06 +00:00
|
|
|
dmabuf_mem_allocator_class_init (GstDmaBufAllocatorClass * klass)
|
2013-02-18 14:18:38 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2013-03-30 11:08:06 +00:00
|
|
|
dmabuf_mem_allocator_init (GstDmaBufAllocator * allocator)
|
2013-02-18 14:18:38 +00:00
|
|
|
{
|
|
|
|
GstAllocator *alloc = GST_ALLOCATOR_CAST (allocator);
|
|
|
|
|
2015-03-18 14:12:03 +00:00
|
|
|
alloc->mem_type = GST_ALLOCATOR_DMABUF;
|
2013-02-18 14:18:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-09-05 00:21:54 +00:00
|
|
|
* gst_dmabuf_allocator_new:
|
2013-02-19 08:35:51 +00:00
|
|
|
*
|
2013-09-05 00:21:54 +00:00
|
|
|
* Return a new dmabuf allocator.
|
2013-02-19 08:35:51 +00:00
|
|
|
*
|
2013-09-05 00:21:54 +00:00
|
|
|
* Returns: (transfer full): a new dmabuf allocator, or NULL if the allocator
|
2013-02-19 09:40:31 +00:00
|
|
|
* isn't available. Use gst_object_unref() to release the allocator after
|
|
|
|
* usage
|
|
|
|
*
|
|
|
|
* Since: 1.2
|
2013-02-18 14:18:38 +00:00
|
|
|
*/
|
|
|
|
GstAllocator *
|
2013-09-05 00:21:54 +00:00
|
|
|
gst_dmabuf_allocator_new (void)
|
2013-02-18 14:18:38 +00:00
|
|
|
{
|
2013-09-05 00:21:54 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (dmabuf_debug, "dmabuf", 0, "dmabuf memory");
|
2013-02-18 14:18:38 +00:00
|
|
|
|
2013-09-05 00:21:54 +00:00
|
|
|
return g_object_new (GST_TYPE_DMABUF_ALLOCATOR, NULL);
|
2013-02-18 14:18:38 +00:00
|
|
|
}
|
|
|
|
|
2013-02-19 09:40:31 +00:00
|
|
|
/**
|
2013-02-19 08:35:51 +00:00
|
|
|
* gst_dmabuf_allocator_alloc:
|
2013-02-19 10:21:40 +00:00
|
|
|
* @allocator: (allow-none): allocator to be used for this memory
|
2013-02-18 14:18:38 +00:00
|
|
|
* @fd: dmabuf file descriptor
|
|
|
|
* @size: memory size
|
2013-02-19 08:35:51 +00:00
|
|
|
*
|
2013-02-19 09:40:31 +00:00
|
|
|
* Return a %GstMemory that wraps a dmabuf file descriptor.
|
2013-02-19 08:35:51 +00:00
|
|
|
*
|
|
|
|
* Returns: (transfer full): a GstMemory based on @allocator.
|
2013-02-18 14:18:38 +00:00
|
|
|
* When the buffer will be released dmabuf allocator will close the @fd.
|
2013-02-19 08:35:51 +00:00
|
|
|
* The memory is only mmapped on gst_buffer_mmap() request.
|
2013-02-19 09:40:31 +00:00
|
|
|
*
|
|
|
|
* Since: 1.2
|
2013-02-18 14:18:38 +00:00
|
|
|
*/
|
|
|
|
GstMemory *
|
|
|
|
gst_dmabuf_allocator_alloc (GstAllocator * allocator, gint fd, gsize size)
|
|
|
|
{
|
2015-04-17 07:31:40 +00:00
|
|
|
g_return_val_if_fail (GST_IS_DMABUF_ALLOCATOR (allocator), NULL);
|
2015-03-18 14:12:03 +00:00
|
|
|
|
2015-04-17 07:31:40 +00:00
|
|
|
return gst_fd_allocator_alloc (allocator, fd, size, GST_FD_MEMORY_FLAG_NONE);
|
2013-02-18 14:18:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-02-19 08:35:51 +00:00
|
|
|
* gst_dmabuf_memory_get_fd:
|
2013-02-18 14:18:38 +00:00
|
|
|
* @mem: the memory to get the file descriptor
|
2013-02-19 08:35:51 +00:00
|
|
|
*
|
2013-02-19 09:40:31 +00:00
|
|
|
* Return the file descriptor associated with @mem.
|
2013-02-19 08:35:51 +00:00
|
|
|
*
|
2014-10-22 12:37:40 +00:00
|
|
|
* Returns: the file descriptor associated with the memory, or -1. The file
|
|
|
|
* descriptor is still owned by the GstMemory. Use dup to take a copy
|
|
|
|
* if you intend to use it beyond the lifetime of this GstMemory.
|
2013-02-19 09:40:31 +00:00
|
|
|
*
|
|
|
|
* Since: 1.2
|
2013-02-18 14:18:38 +00:00
|
|
|
*/
|
|
|
|
gint
|
|
|
|
gst_dmabuf_memory_get_fd (GstMemory * mem)
|
|
|
|
{
|
|
|
|
g_return_val_if_fail (gst_is_dmabuf_memory (mem), -1);
|
|
|
|
|
2015-03-18 14:12:03 +00:00
|
|
|
return gst_fd_memory_get_fd (mem);
|
2013-02-18 14:18:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2013-02-19 08:35:51 +00:00
|
|
|
* gst_is_dmabuf_memory:
|
2013-02-18 14:18:38 +00:00
|
|
|
* @mem: the memory to be check
|
2013-02-19 08:35:51 +00:00
|
|
|
*
|
|
|
|
* Check if @mem is dmabuf memory.
|
|
|
|
*
|
2013-02-19 09:40:31 +00:00
|
|
|
* Returns: %TRUE if @mem is dmabuf memory, otherwise %FALSE
|
|
|
|
*
|
|
|
|
* Since: 1.2
|
2013-02-18 14:18:38 +00:00
|
|
|
*/
|
|
|
|
gboolean
|
|
|
|
gst_is_dmabuf_memory (GstMemory * mem)
|
|
|
|
{
|
2013-07-15 13:23:17 +00:00
|
|
|
return gst_memory_is_type (mem, GST_ALLOCATOR_DMABUF);
|
2013-02-18 14:18:38 +00:00
|
|
|
}
|