13d0407baSopenharmony_ci/*
23d0407baSopenharmony_ci * Copyright  2011 Intel Corporation
33d0407baSopenharmony_ci *
43d0407baSopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a
53d0407baSopenharmony_ci * copy of this software and associated documentation files (the "Software"),
63d0407baSopenharmony_ci * to deal in the Software without restriction, including without limitation
73d0407baSopenharmony_ci * the rights to use, copy, modify, merge, publish, distribute, sublicense,
83d0407baSopenharmony_ci * and/or sell copies of the Software, and to permit persons to whom the
93d0407baSopenharmony_ci * Software is furnished to do so, subject to the following conditions:
103d0407baSopenharmony_ci *
113d0407baSopenharmony_ci * The above copyright notice and this permission notice (including the next
123d0407baSopenharmony_ci * paragraph) shall be included in all copies or substantial portions of the
133d0407baSopenharmony_ci * Software.
143d0407baSopenharmony_ci *
153d0407baSopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
163d0407baSopenharmony_ci * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
173d0407baSopenharmony_ci * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
183d0407baSopenharmony_ci * NONINFRINGEMENT.  IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
193d0407baSopenharmony_ci * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
203d0407baSopenharmony_ci * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
213d0407baSopenharmony_ci * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
223d0407baSopenharmony_ci * DEALINGS IN THE SOFTWARE.
233d0407baSopenharmony_ci *
243d0407baSopenharmony_ci * Authors:
253d0407baSopenharmony_ci *    Benjamin Franzke <benjaminfranzke@googlemail.com>
263d0407baSopenharmony_ci */
273d0407baSopenharmony_ci#ifndef _GBM_H_
283d0407baSopenharmony_ci#define _GBM_H_
293d0407baSopenharmony_ci
303d0407baSopenharmony_ci#define GBM 1
313d0407baSopenharmony_ci
323d0407baSopenharmony_ci#include <stddef.h>
333d0407baSopenharmony_ci#include <stdint.h>
343d0407baSopenharmony_ci
353d0407baSopenharmony_ci#ifdef __cplusplus
363d0407baSopenharmony_ciextern "C" {
373d0407baSopenharmony_ci#endif
383d0407baSopenharmony_ci
393d0407baSopenharmony_ci/**
403d0407baSopenharmony_ci * \file gbm.h
413d0407baSopenharmony_ci * \brief Generic Buffer Manager
423d0407baSopenharmony_ci */
433d0407baSopenharmony_ci
443d0407baSopenharmony_cistruct gbm_device;
453d0407baSopenharmony_cistruct gbm_bo;
463d0407baSopenharmony_cistruct gbm_iSurface;
473d0407baSopenharmony_ci
483d0407baSopenharmony_ci/**
493d0407baSopenharmony_ci * \mainpage The Generic Buffer Manager
503d0407baSopenharmony_ci *
513d0407baSopenharmony_ci * This module provides an abstraction that the caller can use to request a
523d0407baSopenharmony_ci * buffer from the underlying memory management system for the platform.
533d0407baSopenharmony_ci *
543d0407baSopenharmony_ci * This allows the creation of portable code whilst still allowing access to
553d0407baSopenharmony_ci * the underlying memory manager.
563d0407baSopenharmony_ci */
573d0407baSopenharmony_ci
583d0407baSopenharmony_ci/**
593d0407baSopenharmony_ci * Abstraction representing the handle to a buffer allocated by the
603d0407baSopenharmony_ci * manager
613d0407baSopenharmony_ci */
623d0407baSopenharmony_ciunion gbm_bo_handle {
633d0407baSopenharmony_ci    void *ptr;
643d0407baSopenharmony_ci    int32_t s32;
653d0407baSopenharmony_ci    uint32_t u32;
663d0407baSopenharmony_ci    int64_t s64;
673d0407baSopenharmony_ci    uint64_t u64;
683d0407baSopenharmony_ci};
693d0407baSopenharmony_ci
703d0407baSopenharmony_ci/** Format of the allocated buffer */
713d0407baSopenharmony_cienum gbm_bo_format {
723d0407baSopenharmony_ci    /** RGB with 8 bits per channel in a 32 bit value */
733d0407baSopenharmony_ci    GBM_BO_FORMAT_XRGB8888,
743d0407baSopenharmony_ci    /** ARGB with 8 bits per channel in a 32 bit value */
753d0407baSopenharmony_ci    GBM_BO_FORMAT_ARGB8888
763d0407baSopenharmony_ci};
773d0407baSopenharmony_ci
783d0407baSopenharmony_ci/**
793d0407baSopenharmony_ci * The FourCC format codes are taken from the drm_fourcc.h definition, and
803d0407baSopenharmony_ci * re-namespaced. New GBM formats must not be added, unless they are
813d0407baSopenharmony_ci * identical ports from drm_fourcc.
823d0407baSopenharmony_ci */
833d0407baSopenharmony_ci#define gbm_fourcc_code(a, b, c, d)                                                                                    \
843d0407baSopenharmony_ci    ((uint32_t)(a) | ((uint32_t)(b) << 8) | ((uint32_t)(c) << 16) | ((uint32_t)(d) << 24))
853d0407baSopenharmony_ci
863d0407baSopenharmony_ci#define GBM_FORMAT_BIG_ENDIAN (1 << 31) /* format is big endian instead of little endian */
873d0407baSopenharmony_ci
883d0407baSopenharmony_ci/* color index */
893d0407baSopenharmony_ci#define GBM_FORMAT_C8 gbm_fourcc_code('C', '8', ' ', ' ') /* [7:0] C */
903d0407baSopenharmony_ci
913d0407baSopenharmony_ci/* 8 bpp Red */
923d0407baSopenharmony_ci#define GBM_FORMAT_R8 gbm_fourcc_code('R', '8', ' ', ' ') /* [7:0] R */
933d0407baSopenharmony_ci
943d0407baSopenharmony_ci/* 16 bpp RG */
953d0407baSopenharmony_ci#define GBM_FORMAT_GR88 gbm_fourcc_code('G', 'R', '8', '8') /* [15:0] G:R 8:8 little endian */
963d0407baSopenharmony_ci
973d0407baSopenharmony_ci/* 8 bpp RGB */
983d0407baSopenharmony_ci#define GBM_FORMAT_RGB332 gbm_fourcc_code('R', 'G', 'B', '8') /* [7:0] R:G:B 3:3:2 */
993d0407baSopenharmony_ci#define GBM_FORMAT_BGR233 gbm_fourcc_code('B', 'G', 'R', '8') /* [7:0] B:G:R 2:3:3 */
1003d0407baSopenharmony_ci
1013d0407baSopenharmony_ci/* 16 bpp RGB */
1023d0407baSopenharmony_ci#define GBM_FORMAT_XRGB4444 gbm_fourcc_code('X', 'R', '1', '2') /* [15:0] x:R:G:B 4:4:4:4 little endian */
1033d0407baSopenharmony_ci#define GBM_FORMAT_XBGR4444 gbm_fourcc_code('X', 'B', '1', '2') /* [15:0] x:B:G:R 4:4:4:4 little endian */
1043d0407baSopenharmony_ci#define GBM_FORMAT_RGBX4444 gbm_fourcc_code('R', 'X', '1', '2') /* [15:0] R:G:B:x 4:4:4:4 little endian */
1053d0407baSopenharmony_ci#define GBM_FORMAT_BGRX4444 gbm_fourcc_code('B', 'X', '1', '2') /* [15:0] B:G:R:x 4:4:4:4 little endian */
1063d0407baSopenharmony_ci
1073d0407baSopenharmony_ci#define GBM_FORMAT_ARGB4444 gbm_fourcc_code('A', 'R', '1', '2') /* [15:0] A:R:G:B 4:4:4:4 little endian */
1083d0407baSopenharmony_ci#define GBM_FORMAT_ABGR4444 gbm_fourcc_code('A', 'B', '1', '2') /* [15:0] A:B:G:R 4:4:4:4 little endian */
1093d0407baSopenharmony_ci#define GBM_FORMAT_RGBA4444 gbm_fourcc_code('R', 'A', '1', '2') /* [15:0] R:G:B:A 4:4:4:4 little endian */
1103d0407baSopenharmony_ci#define GBM_FORMAT_BGRA4444 gbm_fourcc_code('B', 'A', '1', '2') /* [15:0] B:G:R:A 4:4:4:4 little endian */
1113d0407baSopenharmony_ci
1123d0407baSopenharmony_ci#define GBM_FORMAT_XRGB1555 gbm_fourcc_code('X', 'R', '1', '5') /* [15:0] x:R:G:B 1:5:5:5 little endian */
1133d0407baSopenharmony_ci#define GBM_FORMAT_XBGR1555 gbm_fourcc_code('X', 'B', '1', '5') /* [15:0] x:B:G:R 1:5:5:5 little endian */
1143d0407baSopenharmony_ci#define GBM_FORMAT_RGBX5551 gbm_fourcc_code('R', 'X', '1', '5') /* [15:0] R:G:B:x 5:5:5:1 little endian */
1153d0407baSopenharmony_ci#define GBM_FORMAT_BGRX5551 gbm_fourcc_code('B', 'X', '1', '5') /* [15:0] B:G:R:x 5:5:5:1 little endian */
1163d0407baSopenharmony_ci
1173d0407baSopenharmony_ci#define GBM_FORMAT_ARGB1555 gbm_fourcc_code('A', 'R', '1', '5') /* [15:0] A:R:G:B 1:5:5:5 little endian */
1183d0407baSopenharmony_ci#define GBM_FORMAT_ABGR1555 gbm_fourcc_code('A', 'B', '1', '5') /* [15:0] A:B:G:R 1:5:5:5 little endian */
1193d0407baSopenharmony_ci#define GBM_FORMAT_RGBA5551 gbm_fourcc_code('R', 'A', '1', '5') /* [15:0] R:G:B:A 5:5:5:1 little endian */
1203d0407baSopenharmony_ci#define GBM_FORMAT_BGRA5551 gbm_fourcc_code('B', 'A', '1', '5') /* [15:0] B:G:R:A 5:5:5:1 little endian */
1213d0407baSopenharmony_ci
1223d0407baSopenharmony_ci#define GBM_FORMAT_RGB565 gbm_fourcc_code('R', 'G', '1', '6') /* [15:0] R:G:B 5:6:5 little endian */
1233d0407baSopenharmony_ci#define GBM_FORMAT_BGR565 gbm_fourcc_code('B', 'G', '1', '6') /* [15:0] B:G:R 5:6:5 little endian */
1243d0407baSopenharmony_ci
1253d0407baSopenharmony_ci/* 24 bpp RGB */
1263d0407baSopenharmony_ci#define GBM_FORMAT_RGB888 gbm_fourcc_code('R', 'G', '2', '4') /* [23:0] R:G:B little endian */
1273d0407baSopenharmony_ci#define GBM_FORMAT_BGR888 gbm_fourcc_code('B', 'G', '2', '4') /* [23:0] B:G:R little endian */
1283d0407baSopenharmony_ci
1293d0407baSopenharmony_ci/* 32 bpp RGB */
1303d0407baSopenharmony_ci#define GBM_FORMAT_XRGB8888 gbm_fourcc_code('X', 'R', '2', '4') /* [31:0] x:R:G:B 8:8:8:8 little endian */
1313d0407baSopenharmony_ci#define GBM_FORMAT_XBGR8888 gbm_fourcc_code('X', 'B', '2', '4') /* [31:0] x:B:G:R 8:8:8:8 little endian */
1323d0407baSopenharmony_ci#define GBM_FORMAT_RGBX8888 gbm_fourcc_code('R', 'X', '2', '4') /* [31:0] R:G:B:x 8:8:8:8 little endian */
1333d0407baSopenharmony_ci#define GBM_FORMAT_BGRX8888 gbm_fourcc_code('B', 'X', '2', '4') /* [31:0] B:G:R:x 8:8:8:8 little endian */
1343d0407baSopenharmony_ci
1353d0407baSopenharmony_ci#define GBM_FORMAT_ARGB8888 gbm_fourcc_code('A', 'R', '2', '4') /* [31:0] A:R:G:B 8:8:8:8 little endian */
1363d0407baSopenharmony_ci#define GBM_FORMAT_ABGR8888 gbm_fourcc_code('A', 'B', '2', '4') /* [31:0] A:B:G:R 8:8:8:8 little endian */
1373d0407baSopenharmony_ci#define GBM_FORMAT_RGBA8888 gbm_fourcc_code('R', 'A', '2', '4') /* [31:0] R:G:B:A 8:8:8:8 little endian */
1383d0407baSopenharmony_ci#define GBM_FORMAT_BGRA8888 gbm_fourcc_code('B', 'A', '2', '4') /* [31:0] B:G:R:A 8:8:8:8 little endian */
1393d0407baSopenharmony_ci
1403d0407baSopenharmony_ci#define GBM_FORMAT_XRGB2101010 gbm_fourcc_code('X', 'R', '3', '0') /* [31:0] x:R:G:B 2:10:10:10 little endian */
1413d0407baSopenharmony_ci#define GBM_FORMAT_XBGR2101010 gbm_fourcc_code('X', 'B', '3', '0') /* [31:0] x:B:G:R 2:10:10:10 little endian */
1423d0407baSopenharmony_ci#define GBM_FORMAT_RGBX1010102 gbm_fourcc_code('R', 'X', '3', '0') /* [31:0] R:G:B:x 10:10:10:2 little endian */
1433d0407baSopenharmony_ci#define GBM_FORMAT_BGRX1010102 gbm_fourcc_code('B', 'X', '3', '0') /* [31:0] B:G:R:x 10:10:10:2 little endian */
1443d0407baSopenharmony_ci
1453d0407baSopenharmony_ci#define GBM_FORMAT_ARGB2101010 gbm_fourcc_code('A', 'R', '3', '0') /* [31:0] A:R:G:B 2:10:10:10 little endian */
1463d0407baSopenharmony_ci#define GBM_FORMAT_ABGR2101010 gbm_fourcc_code('A', 'B', '3', '0') /* [31:0] A:B:G:R 2:10:10:10 little endian */
1473d0407baSopenharmony_ci#define GBM_FORMAT_RGBA1010102 gbm_fourcc_code('R', 'A', '3', '0') /* [31:0] R:G:B:A 10:10:10:2 little endian */
1483d0407baSopenharmony_ci#define GBM_FORMAT_BGRA1010102 gbm_fourcc_code('B', 'A', '3', '0') /* [31:0] B:G:R:A 10:10:10:2 little endian */
1493d0407baSopenharmony_ci
1503d0407baSopenharmony_ci/* packed YCbCr */
1513d0407baSopenharmony_ci#define GBM_FORMAT_YUYV gbm_fourcc_code('Y', 'U', 'Y', 'V') /* [31:0] Cr0:Y1:Cb0:Y0 8:8:8:8 little endian */
1523d0407baSopenharmony_ci#define GBM_FORMAT_YVYU gbm_fourcc_code('Y', 'V', 'Y', 'U') /* [31:0] Cb0:Y1:Cr0:Y0 8:8:8:8 little endian */
1533d0407baSopenharmony_ci#define GBM_FORMAT_UYVY gbm_fourcc_code('U', 'Y', 'V', 'Y') /* [31:0] Y1:Cr0:Y0:Cb0 8:8:8:8 little endian */
1543d0407baSopenharmony_ci#define GBM_FORMAT_VYUY gbm_fourcc_code('V', 'Y', 'U', 'Y') /* [31:0] Y1:Cb0:Y0:Cr0 8:8:8:8 little endian */
1553d0407baSopenharmony_ci
1563d0407baSopenharmony_ci#define GBM_FORMAT_AYUV gbm_fourcc_code('A', 'Y', 'U', 'V') /* [31:0] A:Y:Cb:Cr 8:8:8:8 little endian */
1573d0407baSopenharmony_ci
1583d0407baSopenharmony_ci/*
1593d0407baSopenharmony_ci * 2 plane YCbCr
1603d0407baSopenharmony_ci * index 0 = Y plane, [7:0] Y
1613d0407baSopenharmony_ci * index 1 = Cr:Cb plane, [15:0] Cr:Cb little endian
1623d0407baSopenharmony_ci * or
1633d0407baSopenharmony_ci * index 1 = Cb:Cr plane, [15:0] Cb:Cr little endian
1643d0407baSopenharmony_ci */
1653d0407baSopenharmony_ci#define GBM_FORMAT_NV12 gbm_fourcc_code('N', 'V', '1', '2') /* 2x2 subsampled Cr:Cb plane */
1663d0407baSopenharmony_ci#define GBM_FORMAT_NV21 gbm_fourcc_code('N', 'V', '2', '1') /* 2x2 subsampled Cb:Cr plane */
1673d0407baSopenharmony_ci#define GBM_FORMAT_NV16 gbm_fourcc_code('N', 'V', '1', '6') /* 2x1 subsampled Cr:Cb plane */
1683d0407baSopenharmony_ci#define GBM_FORMAT_NV61 gbm_fourcc_code('N', 'V', '6', '1') /* 2x1 subsampled Cb:Cr plane */
1693d0407baSopenharmony_ci
1703d0407baSopenharmony_ci/*
1713d0407baSopenharmony_ci * 3 plane YCbCr
1723d0407baSopenharmony_ci * index 0: Y plane, [7:0] Y
1733d0407baSopenharmony_ci * index 1: Cb plane, [7:0] Cb
1743d0407baSopenharmony_ci * index 2: Cr plane, [7:0] Cr
1753d0407baSopenharmony_ci * or
1763d0407baSopenharmony_ci * index 1: Cr plane, [7:0] Cr
1773d0407baSopenharmony_ci * index 2: Cb plane, [7:0] Cb
1783d0407baSopenharmony_ci */
1793d0407baSopenharmony_ci#define GBM_FORMAT_YUV410 gbm_fourcc_code('Y', 'U', 'V', '9') /* 4x4 subsampled Cb (1) and Cr (2) planes */
1803d0407baSopenharmony_ci#define GBM_FORMAT_YVU410 gbm_fourcc_code('Y', 'V', 'U', '9') /* 4x4 subsampled Cr (1) and Cb (2) planes */
1813d0407baSopenharmony_ci#define GBM_FORMAT_YUV411 gbm_fourcc_code('Y', 'U', '1', '1') /* 4x1 subsampled Cb (1) and Cr (2) planes */
1823d0407baSopenharmony_ci#define GBM_FORMAT_YVU411 gbm_fourcc_code('Y', 'V', '1', '1') /* 4x1 subsampled Cr (1) and Cb (2) planes */
1833d0407baSopenharmony_ci#define GBM_FORMAT_YUV420 gbm_fourcc_code('Y', 'U', '1', '2') /* 2x2 subsampled Cb (1) and Cr (2) planes */
1843d0407baSopenharmony_ci#define GBM_FORMAT_YVU420 gbm_fourcc_code('Y', 'V', '1', '2') /* 2x2 subsampled Cr (1) and Cb (2) planes */
1853d0407baSopenharmony_ci#define GBM_FORMAT_YUV422 gbm_fourcc_code('Y', 'U', '1', '6') /* 2x1 subsampled Cb (1) and Cr (2) planes */
1863d0407baSopenharmony_ci#define GBM_FORMAT_YVU422 gbm_fourcc_code('Y', 'V', '1', '6') /* 2x1 subsampled Cr (1) and Cb (2) planes */
1873d0407baSopenharmony_ci#define GBM_FORMAT_YUV444 gbm_fourcc_code('Y', 'U', '2', '4') /* non-subsampled Cb (1) and Cr (2) planes */
1883d0407baSopenharmony_ci#define GBM_FORMAT_YVU444 gbm_fourcc_code('Y', 'V', '2', '4') /* non-subsampled Cr (1) and Cb (2) planes */
1893d0407baSopenharmony_ci
1903d0407baSopenharmony_ci/**
1913d0407baSopenharmony_ci * Flags to indicate the intended use for the buffer - these are passed into
1923d0407baSopenharmony_ci * gbm_bo_create(). The caller must set the union of all the flags that are
1933d0407baSopenharmony_ci * appropriate
1943d0407baSopenharmony_ci *
1953d0407baSopenharmony_ci * \sa Use gbm_device_is_format_supported() to check if the combination of format
1963d0407baSopenharmony_ci * and use flags are supported
1973d0407baSopenharmony_ci */
1983d0407baSopenharmony_cienum gbm_bo_flags {
1993d0407baSopenharmony_ci    /**
2003d0407baSopenharmony_ci     * Buffer is going to be presented to the screen using an API such as KMS
2013d0407baSopenharmony_ci     */
2023d0407baSopenharmony_ci    GBM_BO_USE_SCANOUT = (1 << 0),
2033d0407baSopenharmony_ci    /**
2043d0407baSopenharmony_ci     * Buffer is going to be used as cursor
2053d0407baSopenharmony_ci     */
2063d0407baSopenharmony_ci    GBM_BO_USE_CURSOR = (1 << 1),
2073d0407baSopenharmony_ci    /**
2083d0407baSopenharmony_ci     * Deprecated
2093d0407baSopenharmony_ci     */
2103d0407baSopenharmony_ci    GBM_BO_USE_CURSOR_64X64 = GBM_BO_USE_CURSOR,
2113d0407baSopenharmony_ci    /**
2123d0407baSopenharmony_ci     * Buffer is to be used for rendering - for example it is going to be used
2133d0407baSopenharmony_ci     * as the storage for a color buffer
2143d0407baSopenharmony_ci     */
2153d0407baSopenharmony_ci    GBM_BO_USE_RENDERING = (1 << 2),
2163d0407baSopenharmony_ci    /**
2173d0407baSopenharmony_ci     * Buffer can be used for gbm_bo_write.  This is guaranteed to work
2183d0407baSopenharmony_ci     * with GBM_BO_USE_CURSOR, but may not work for other combinations.
2193d0407baSopenharmony_ci     */
2203d0407baSopenharmony_ci    GBM_BO_USE_WRITE = (1 << 3),
2213d0407baSopenharmony_ci    /**
2223d0407baSopenharmony_ci     * Buffer is linear, i.e. not tiled.
2233d0407baSopenharmony_ci     */
2243d0407baSopenharmony_ci    GBM_BO_USE_LINEAR = (1 << 4),
2253d0407baSopenharmony_ci};
2263d0407baSopenharmony_ci
2273d0407baSopenharmony_ciint gbm_device_get_fd(struct gbm_device *gbm);
2283d0407baSopenharmony_ci
2293d0407baSopenharmony_ciconst char *gbm_device_get_backend_name(struct gbm_device *gbm);
2303d0407baSopenharmony_ci
2313d0407baSopenharmony_ciint gbm_device_is_format_supported(struct gbm_device *gbm, uint32_t format, uint32_t usage);
2323d0407baSopenharmony_ci
2333d0407baSopenharmony_ciint gbm_device_get_format_modifier_plane_count(struct gbm_device *gbm, uint32_t format, uint64_t modifier);
2343d0407baSopenharmony_ci
2353d0407baSopenharmony_civoid gbm_device_destroy(struct gbm_device *gbm);
2363d0407baSopenharmony_ci
2373d0407baSopenharmony_cistruct gbm_device *gbm_create_device(int fd);
2383d0407baSopenharmony_ci
2393d0407baSopenharmony_cistruct gbm_bo *gbm_bo_create(struct gbm_device *gbm, uint32_t width, uint32_t height, uint32_t format, uint32_t flags);
2403d0407baSopenharmony_ci
2413d0407baSopenharmony_cistruct gbm_bo *gbm_bo_create_with_modifiers(struct gbm_device *gbm, uint32_t width, uint32_t height, uint32_t format,
2423d0407baSopenharmony_ci                                            const uint64_t *modifiers, const unsigned int count);
2433d0407baSopenharmony_ci
2443d0407baSopenharmony_ci#define GBM_BO_IMPORT_WL_BUFFER 0x5501
2453d0407baSopenharmony_ci#define GBM_BO_IMPORT_EGL_IMAGE 0x5502
2463d0407baSopenharmony_ci#define GBM_BO_IMPORT_FD 0x5503
2473d0407baSopenharmony_ci#define GBM_BO_IMPORT_FD_MODIFIER 0x5504
2483d0407baSopenharmony_ci
2493d0407baSopenharmony_cistruct gbm_import_fd_data {
2503d0407baSopenharmony_ci    int fd;
2513d0407baSopenharmony_ci    uint32_t width;
2523d0407baSopenharmony_ci    uint32_t height;
2533d0407baSopenharmony_ci    uint32_t stride;
2543d0407baSopenharmony_ci    uint32_t format;
2553d0407baSopenharmony_ci};
2563d0407baSopenharmony_ci
2573d0407baSopenharmony_cistruct gbm_import_fd_modifier_data {
2583d0407baSopenharmony_ci    uint32_t width;
2593d0407baSopenharmony_ci    uint32_t height;
2603d0407baSopenharmony_ci    uint32_t format;
2613d0407baSopenharmony_ci    uint32_t num_fds;
2623d0407baSopenharmony_ci    int fds[4];
2633d0407baSopenharmony_ci    int strides[4];
2643d0407baSopenharmony_ci    int offsets[4];
2653d0407baSopenharmony_ci    uint64_t modifier;
2663d0407baSopenharmony_ci};
2673d0407baSopenharmony_ci
2683d0407baSopenharmony_cistruct gbm_bo *bm_bo_import(struct gbm_device *gbm, uint32_t type, void *buffer, uint32_t usage);
2693d0407baSopenharmony_ci
2703d0407baSopenharmony_ci/**
2713d0407baSopenharmony_ci * Flags to indicate the type of mapping for the buffer - these are
2723d0407baSopenharmony_ci * passed into gbm_bo_map(). The caller must set the union of all the
2733d0407baSopenharmony_ci * flags that are appropriate.
2743d0407baSopenharmony_ci *
2753d0407baSopenharmony_ci * These flags are independent of the GBM_BO_USE_* creation flags. However,
2763d0407baSopenharmony_ci * mapping the buffer may require copying to/from a staging buffer.
2773d0407baSopenharmony_ci *
2783d0407baSopenharmony_ci * See also: pipe_transfer_usage
2793d0407baSopenharmony_ci */
2803d0407baSopenharmony_cienum gbm_bo_transfer_flags {
2813d0407baSopenharmony_ci    /**
2823d0407baSopenharmony_ci     * Buffer contents read back (or accessed directly) at transfer
2833d0407baSopenharmony_ci     * create time.
2843d0407baSopenharmony_ci     */
2853d0407baSopenharmony_ci    GBM_BO_TRANSFER_READ = (1 << 0),
2863d0407baSopenharmony_ci    /**
2873d0407baSopenharmony_ci     * Buffer contents will be written back at unmap time
2883d0407baSopenharmony_ci     * (or modified as a result of being accessed directly).
2893d0407baSopenharmony_ci     */
2903d0407baSopenharmony_ci    GBM_BO_TRANSFER_WRITE = (1 << 1),
2913d0407baSopenharmony_ci    /**
2923d0407baSopenharmony_ci     * Read/modify/write
2933d0407baSopenharmony_ci     */
2943d0407baSopenharmony_ci    GBM_BO_TRANSFER_READ_WRITE = (GBM_BO_TRANSFER_READ | GBM_BO_TRANSFER_WRITE),
2953d0407baSopenharmony_ci};
2963d0407baSopenharmony_ci
2973d0407baSopenharmony_civoid *gbm_bo_map(struct gbm_bo *bo, uint32_t x, uint32_t y, uint32_t width, uint32_t height, uint32_t flags,
2983d0407baSopenharmony_ci                 uint32_t *stride, void **map_data);
2993d0407baSopenharmony_ci
3003d0407baSopenharmony_civoid gbm_bo_unmap(struct gbm_bo *bo, void *map_data);
3013d0407baSopenharmony_ci
3023d0407baSopenharmony_ciuint32_t gbm_bo_get_width(struct gbm_bo *bo);
3033d0407baSopenharmony_ci
3043d0407baSopenharmony_ciuint32_t gbm_bo_get_height(struct gbm_bo *bo);
3053d0407baSopenharmony_ci
3063d0407baSopenharmony_ciuint32_t gbm_bo_get_stride(struct gbm_bo *bo);
3073d0407baSopenharmony_ci
3083d0407baSopenharmony_ciuint32_t gbm_bo_get_stride_for_plane(struct gbm_bo *bo, int plane);
3093d0407baSopenharmony_ci
3103d0407baSopenharmony_ciuint32_t gbm_bo_get_format(struct gbm_bo *bo);
3113d0407baSopenharmony_ci
3123d0407baSopenharmony_ciuint32_t gbm_bo_get_bpp(struct gbm_bo *bo);
3133d0407baSopenharmony_ci
3143d0407baSopenharmony_ciuint32_t gbm_bo_get_offset(struct gbm_bo *bo, int plane);
3153d0407baSopenharmony_ci
3163d0407baSopenharmony_cistruct gbm_device *gbm_bo_get_device(struct gbm_bo *bo);
3173d0407baSopenharmony_ci
3183d0407baSopenharmony_ciunion gbm_bo_handle gbm_bo_get_handle(struct gbm_bo *bo);
3193d0407baSopenharmony_ci
3203d0407baSopenharmony_ciint gbm_bo_get_fd(struct gbm_bo *bo);
3213d0407baSopenharmony_ci
3223d0407baSopenharmony_ciuint64_t gbm_bo_get_modifier(struct gbm_bo *bo);
3233d0407baSopenharmony_ci
3243d0407baSopenharmony_ciint gbm_bo_get_plane_count(struct gbm_bo *bo);
3253d0407baSopenharmony_ci
3263d0407baSopenharmony_ciunion gbm_bo_handle gbm_bo_get_handle_for_plane(struct gbm_bo *bo, int plane);
3273d0407baSopenharmony_ci
3283d0407baSopenharmony_ciint gbm_bo_write(struct gbm_bo *bo, const void *buf, size_t count);
3293d0407baSopenharmony_ci
3303d0407baSopenharmony_civoid gbm_bo_set_user_data(struct gbm_bo *bo, void *data, void (*destroy_user_data)(struct gbm_bo *, void *));
3313d0407baSopenharmony_ci
3323d0407baSopenharmony_civoid *gbm_bo_get_user_data(struct gbm_bo *bo);
3333d0407baSopenharmony_ci
3343d0407baSopenharmony_civoid gbm_bo_destroy(struct gbm_bo *bo);
3353d0407baSopenharmony_ci
3363d0407baSopenharmony_cistruct gbm_iSurface *gbm_iSurface_create(struct gbm_device *gbm, uint32_t width, uint32_t height, uint32_t format,
3373d0407baSopenharmony_ci                                         uint32_t flags);
3383d0407baSopenharmony_ci
3393d0407baSopenharmony_cistruct gbm_iSurface *gbm_iSurface_create_with_modifiers(struct gbm_device *gbm, uint32_t width, uint32_t height,
3403d0407baSopenharmony_ci                                                        uint32_t format, const uint64_t *modifiers,
3413d0407baSopenharmony_ci                                                        const unsigned int count);
3423d0407baSopenharmony_ci
3433d0407baSopenharmony_cistruct gbm_bo *gbm_iSurface_lock_front_buffer(struct gbm_iSurface *iSurface);
3443d0407baSopenharmony_ci
3453d0407baSopenharmony_civoid gbm_iSurface_release_buffer(struct gbm_iSurface *iSurface, struct gbm_bo *bo);
3463d0407baSopenharmony_ci
3473d0407baSopenharmony_ciint gbm_iSurface_has_free_buffers(struct gbm_iSurface *iSurface);
3483d0407baSopenharmony_ci
3493d0407baSopenharmony_civoid gbm_iSurface_destroy(struct gbm_iSurface *iSurface);
3503d0407baSopenharmony_ci
3513d0407baSopenharmony_ci#ifdef __cplusplus
3523d0407baSopenharmony_ci}
3533d0407baSopenharmony_ci#endif
3543d0407baSopenharmony_ci
3553d0407baSopenharmony_ci#endif
356