mutter/src/backends/native/meta-drm-buffer-import.h

51 lines
2.0 KiB
C
Raw Normal View History

2019-05-24 17:07:14 +03:00
/*
* Copyright (C) 2018 Canonical Ltd.
* Copyright (C) 2019 Red Hat Inc.
* Copyright (C) 2019 DisplayLink (UK) Ltd.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of the
* License, or (at your option) any later version.
*
* This program 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
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, see <http://www.gnu.org/licenses/>.
2019-05-24 17:07:14 +03:00
*
*/
#pragma once
2019-05-24 17:07:14 +03:00
#include <gbm.h>
#include "backends/native/meta-drm-buffer.h"
#include "backends/native/meta-drm-buffer-gbm.h"
#include "backends/native/meta-gpu-kms.h"
#define META_TYPE_DRM_BUFFER_IMPORT (meta_drm_buffer_import_get_type ())
G_DECLARE_FINAL_TYPE (MetaDrmBufferImport,
meta_drm_buffer_import,
META, DRM_BUFFER_IMPORT,
MetaDrmBuffer)
/*
* MetaDrmBufferImport is a buffer that refers to the storage of a
* MetaDrmBufferGbm buffer on another MetaGpuKms.
*
* When creating an imported buffer, the given GBM buffer is exported
* as a dma_buf and then imported to the given MetaGpuKms. A reference
* is kept to the GBM buffer so that it won't disappear while the
* imported buffer exists.
*
* The import has a high chance of failing under normal operating
* conditions and needs to be handled with fallbacks to something else.
*/
MetaDrmBufferImport * meta_drm_buffer_import_new (MetaDeviceFile *device_file,
struct gbm_device *gbm_device,
MetaDrmBufferGbm *buffer_gbm,
GError **error);