blob: dec43fc9cd31ef6f5257d8a78c69730b099a6695 [file] [log] [blame]
Gurchetan Singh46faf6b2016-08-05 14:40:07 -07001/*
Daniele Castagna7a755de2016-12-16 17:32:30 -05002 * Copyright 2016 The Chromium OS Authors. All rights reserved.
Gurchetan Singh46faf6b2016-08-05 14:40:07 -07003 * Use of this source code is governed by a BSD-style license that can be
4 * found in the LICENSE file.
5 */
6
7#ifndef DRV_H_
8#define DRV_H_
9
10#ifdef __cplusplus
11extern "C" {
12#endif
13
Gurchetan Singhf3b22da2016-11-21 10:46:38 -080014#include <drm_fourcc.h>
David Stevens26fe6822020-03-09 12:23:42 +000015#include <stdbool.h>
Gurchetan Singh46faf6b2016-08-05 14:40:07 -070016#include <stdint.h>
Yiwei Zhangb7a64442021-09-30 05:13:10 +000017#include <stdlib.h>
Gurchetan Singh46faf6b2016-08-05 14:40:07 -070018
19#define DRV_MAX_PLANES 4
20
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -080021// clang-format off
Gurchetan Singh46faf6b2016-08-05 14:40:07 -070022/* Use flags */
Gurchetan Singh458976f2016-11-23 17:32:33 -080023#define BO_USE_NONE 0
24#define BO_USE_SCANOUT (1ull << 0)
25#define BO_USE_CURSOR (1ull << 1)
26#define BO_USE_CURSOR_64X64 BO_USE_CURSOR
27#define BO_USE_RENDERING (1ull << 2)
Gurchetan Singh48b4c082019-09-13 18:36:52 -070028/* Skip for GBM_BO_USE_WRITE */
29#define BO_USE_LINEAR (1ull << 4)
30#define BO_USE_TEXTURE (1ull << 5)
31#define BO_USE_CAMERA_WRITE (1ull << 6)
32#define BO_USE_CAMERA_READ (1ull << 7)
33#define BO_USE_PROTECTED (1ull << 8)
34#define BO_USE_SW_READ_OFTEN (1ull << 9)
35#define BO_USE_SW_READ_RARELY (1ull << 10)
36#define BO_USE_SW_WRITE_OFTEN (1ull << 11)
37#define BO_USE_SW_WRITE_RARELY (1ull << 12)
David Stevens99824212019-12-25 16:35:55 +090038#define BO_USE_HW_VIDEO_DECODER (1ull << 13)
39#define BO_USE_HW_VIDEO_ENCODER (1ull << 14)
David Stevens26fe6822020-03-09 12:23:42 +000040#define BO_USE_TEST_ALLOC (1ull << 15)
Rob Clark6f83a442020-10-05 12:10:51 -070041#define BO_USE_FRONT_RENDERING (1ull << 16)
42#define BO_USE_RENDERSCRIPT (1ull << 17)
Yiwei Zhangbb9d4af2021-06-20 19:23:38 +000043#define BO_USE_GPU_DATA_BUFFER (1ull << 18)
Jason Macnake8b40542022-07-19 14:46:18 -070044#define BO_USE_SENSOR_DIRECT_DATA (1ull << 19)
Kristian H. Kristensen3cb5bba2018-04-04 16:10:42 -070045
Dominik Behr6e6dc492019-10-09 15:43:52 -070046/* Quirks for allocating a buffer. */
47#define BO_QUIRK_NONE 0
48#define BO_QUIRK_DUMB32BPP (1ull << 0)
Gurchetan Singh46faf6b2016-08-05 14:40:07 -070049
Gurchetan Singhf7f633a2017-09-28 17:02:12 -070050/* Map flags */
51#define BO_MAP_NONE 0
52#define BO_MAP_READ (1 << 0)
53#define BO_MAP_WRITE (1 << 1)
54#define BO_MAP_READ_WRITE (BO_MAP_READ | BO_MAP_WRITE)
Joe Kniss65705852017-06-29 15:02:46 -070055
Gurchetan Singhf3b22da2016-11-21 10:46:38 -080056/* This is our extension to <drm_fourcc.h>. We need to make sure we don't step
57 * on the namespace of already defined formats, which can be done by using invalid
58 * fourcc codes.
59 */
Gurchetan Singhf3b22da2016-11-21 10:46:38 -080060#define DRM_FORMAT_NONE fourcc_code('0', '0', '0', '0')
Gurchetan Singh03f13562017-02-08 15:21:14 -080061#define DRM_FORMAT_YVU420_ANDROID fourcc_code('9', '9', '9', '7')
Gurchetan Singhf3b22da2016-11-21 10:46:38 -080062#define DRM_FORMAT_FLEX_IMPLEMENTATION_DEFINED fourcc_code('9', '9', '9', '8')
63#define DRM_FORMAT_FLEX_YCbCr_420_888 fourcc_code('9', '9', '9', '9')
Gurchetan Singh46faf6b2016-08-05 14:40:07 -070064
Jasmine Chenc7aa9742019-08-14 15:28:22 +080065/* This is a 10-bit bayer format for private reprocessing on MediaTek ISP. It's
66 * a private RAW format that other DRM drivers will never support and thus
67 * making it not upstreamable (i.e., defined in official DRM headers). */
68#define DRM_FORMAT_MTISP_SXYZW10 fourcc_code('M', 'B', '1', '0')
69
Miguel Casas055a6aa2019-04-30 18:11:40 -040070// TODO(crbug.com/958181): remove this definition once drm_fourcc.h contains it.
71#ifndef DRM_FORMAT_P010
72#define DRM_FORMAT_P010 fourcc_code('P', '0', '1', '0')
73#endif
74
Vipin Ananda0af3092020-06-17 10:53:02 +053075//TODO: remove this defination once drm_fourcc.h contains it.
76#ifndef I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS
77#define I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS fourcc_mod_code(INTEL, 6)
78#endif
79
Vipin Anand97e07de2022-08-12 04:47:34 +000080//TODO: remove this defination once drm_fourcc.h contains it.
81#ifndef I915_FORMAT_MOD_4_TILED
82#define I915_FORMAT_MOD_4_TILED fourcc_mod_code(INTEL, 9)
83#endif
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -080084// clang-format on
Gurchetan Singh46faf6b2016-08-05 14:40:07 -070085struct driver;
86struct bo;
Gurchetan Singh6b41fb52017-03-01 20:14:39 -080087struct combination;
Gurchetan Singh46faf6b2016-08-05 14:40:07 -070088
89union bo_handle {
Gurchetan Singhb72badb2016-08-19 16:26:46 -070090 void *ptr;
91 int32_t s32;
92 uint32_t u32;
93 int64_t s64;
94 uint64_t u64;
Gurchetan Singh46faf6b2016-08-05 14:40:07 -070095};
96
97struct drv_import_fd_data {
Gurchetan Singhb72badb2016-08-19 16:26:46 -070098 int fds[DRV_MAX_PLANES];
99 uint32_t strides[DRV_MAX_PLANES];
100 uint32_t offsets[DRV_MAX_PLANES];
Gurchetan Singh52155b42021-01-27 17:55:17 -0800101 uint64_t format_modifier;
Gurchetan Singhb72badb2016-08-19 16:26:46 -0700102 uint32_t width;
103 uint32_t height;
Gurchetan Singhf3b22da2016-11-21 10:46:38 -0800104 uint32_t format;
David Stevensb42624c2020-09-10 10:50:26 +0900105 uint32_t tiling;
Gurchetan Singha1892b22017-09-28 16:40:52 -0700106 uint64_t use_flags;
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700107};
108
Gurchetan Singh47e629b2017-11-02 14:07:18 -0700109struct vma {
Gurchetan Singh80fc2b92017-02-14 17:47:02 -0800110 void *addr;
111 size_t length;
112 uint32_t handle;
Gurchetan Singhe29a6402017-10-05 14:52:24 -0700113 uint32_t map_flags;
Gurchetan Singh80fc2b92017-02-14 17:47:02 -0800114 int32_t refcount;
Satyajit Sahu77b70552018-05-03 16:35:24 +0530115 uint32_t map_strides[DRV_MAX_PLANES];
Gurchetan Singh80fc2b92017-02-14 17:47:02 -0800116 void *priv;
117};
118
Gurchetan Singh1ef809e2017-11-06 11:07:52 -0800119struct rectangle {
120 uint32_t x;
121 uint32_t y;
122 uint32_t width;
123 uint32_t height;
124};
125
Gurchetan Singh47e629b2017-11-02 14:07:18 -0700126struct mapping {
127 struct vma *vma;
Gurchetan Singh1ef809e2017-11-06 11:07:52 -0800128 struct rectangle rect;
129 uint32_t refcount;
Gurchetan Singh47e629b2017-11-02 14:07:18 -0700130};
131
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800132struct driver *drv_create(int fd);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700133
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800134void drv_destroy(struct driver *drv);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700135
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800136int drv_get_fd(struct driver *drv);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700137
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800138const char *drv_get_name(struct driver *drv);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700139
Gurchetan Singha1892b22017-09-28 16:40:52 -0700140struct combination *drv_get_combination(struct driver *drv, uint32_t format, uint64_t use_flags);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700141
Gurchetan Singh18578ed2017-08-03 18:23:27 -0700142struct bo *drv_bo_new(struct driver *drv, uint32_t width, uint32_t height, uint32_t format,
David Stevens26fe6822020-03-09 12:23:42 +0000143 uint64_t use_flags, bool is_test_buffer);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700144
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800145struct bo *drv_bo_create(struct driver *drv, uint32_t width, uint32_t height, uint32_t format,
Gurchetan Singha1892b22017-09-28 16:40:52 -0700146 uint64_t use_flags);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700147
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800148struct bo *drv_bo_create_with_modifiers(struct driver *drv, uint32_t width, uint32_t height,
149 uint32_t format, const uint64_t *modifiers, uint32_t count);
Kristian H. Kristensenb1efbd82016-09-06 11:43:26 -0700150
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800151void drv_bo_destroy(struct bo *bo);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700152
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800153struct bo *drv_bo_import(struct driver *drv, struct drv_import_fd_data *data);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700154
Gurchetan Singh1ef809e2017-11-06 11:07:52 -0800155void *drv_bo_map(struct bo *bo, const struct rectangle *rect, uint32_t map_flags,
156 struct mapping **map_data, size_t plane);
Gurchetan Singh1a31e602016-10-06 10:58:00 -0700157
Gurchetan Singh47e629b2017-11-02 14:07:18 -0700158int drv_bo_unmap(struct bo *bo, struct mapping *mapping);
Gurchetan Singhff741412017-09-13 17:54:36 -0700159
Gurchetan Singh47e629b2017-11-02 14:07:18 -0700160int drv_bo_invalidate(struct bo *bo, struct mapping *mapping);
Gurchetan Singhc2ad63e2017-10-09 17:59:47 -0700161
Jason Macnak1de7f662020-01-24 15:05:57 -0800162int drv_bo_flush(struct bo *bo, struct mapping *mapping);
163
Gurchetan Singhbd1b1b52018-03-29 16:34:53 -0700164int drv_bo_flush_or_unmap(struct bo *bo, struct mapping *mapping);
Gurchetan Singh1a31e602016-10-06 10:58:00 -0700165
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800166uint32_t drv_bo_get_width(struct bo *bo);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700167
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800168uint32_t drv_bo_get_height(struct bo *bo);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700169
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800170size_t drv_bo_get_num_planes(struct bo *bo);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700171
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800172union bo_handle drv_bo_get_plane_handle(struct bo *bo, size_t plane);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700173
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800174int drv_bo_get_plane_fd(struct bo *bo, size_t plane);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700175
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800176uint32_t drv_bo_get_plane_offset(struct bo *bo, size_t plane);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700177
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800178uint32_t drv_bo_get_plane_size(struct bo *bo, size_t plane);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700179
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800180uint32_t drv_bo_get_plane_stride(struct bo *bo, size_t plane);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700181
Gurchetan Singh52155b42021-01-27 17:55:17 -0800182uint64_t drv_bo_get_format_modifier(struct bo *bo);
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700183
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800184uint32_t drv_bo_get_format(struct bo *bo);
Gurchetan Singh2e786ad2016-08-24 18:31:23 -0700185
Yiwei Zhang1f9b9002021-09-15 21:28:51 +0000186uint32_t drv_bo_get_tiling(struct bo *bo);
187
188uint64_t drv_bo_get_use_flags(struct bo *bo);
189
190size_t drv_bo_get_total_size(struct bo *bo);
191
Yiwei Zhangb7a64442021-09-30 05:13:10 +0000192uint32_t drv_get_standard_fourcc(uint32_t fourcc_internal);
193
Kristian H. Kristensen22291902018-04-04 13:40:47 -0700194uint32_t drv_bytes_per_pixel_from_format(uint32_t format, size_t plane);
Gurchetan Singh6423ecb2017-03-29 08:23:40 -0700195
Gurchetan Singh1ef809e2017-11-06 11:07:52 -0800196uint32_t drv_stride_from_format(uint32_t format, uint32_t width, size_t plane);
197
Yiwei Zhangb8ad7b82021-10-01 17:55:14 +0000198void drv_resolve_format_and_use_flags(struct driver *drv, uint32_t format, uint64_t use_flags,
199 uint32_t *out_format, uint64_t *out_use_flags);
Gurchetan Singhbfba8c22016-08-16 17:57:10 -0700200
Yiwei Zhangc1413ea2021-09-17 08:20:21 +0000201uint64_t drv_resolve_use_flags(struct driver *drv, uint32_t format, uint64_t use_flags);
202
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800203size_t drv_num_planes_from_format(uint32_t format);
Gurchetan Singh2a119342016-11-02 10:40:51 -0700204
ChromeOS Developer44588bb2020-03-02 16:32:09 +0100205size_t drv_num_planes_from_modifier(struct driver *drv, uint32_t format, uint64_t modifier);
206
Gurchetan Singh1b1d56a2017-03-10 16:25:23 -0800207uint32_t drv_num_buffers_per_bo(struct bo *bo);
Gurchetan Singh2e786ad2016-08-24 18:31:23 -0700208
Gurchetan Singhbc4f0232019-06-27 20:05:54 -0700209int drv_resource_info(struct bo *bo, uint32_t strides[DRV_MAX_PLANES],
Yiwei Zhanga1e93fd2021-04-30 07:01:55 +0000210 uint32_t offsets[DRV_MAX_PLANES], uint64_t *format_modifier);
Gurchetan Singhbc4f0232019-06-27 20:05:54 -0700211
Jason Macnak336fd052021-09-29 11:10:06 -0700212uint32_t drv_get_max_texture_2d_size(struct driver *drv);
213
Yiwei Zhang7b3cbea2022-07-13 00:25:11 +0000214enum drv_log_level {
215 DRV_LOGV,
216 DRV_LOGD,
217 DRV_LOGI,
218 DRV_LOGE,
219};
220
221#define _drv_log(level, format, ...) \
Alistair Strachan0cfaaa52018-03-19 14:03:23 -0700222 do { \
Yiwei Zhang7b3cbea2022-07-13 00:25:11 +0000223 drv_log_prefix(level, "minigbm", __FILE__, __LINE__, format, ##__VA_ARGS__); \
Alistair Strachan0cfaaa52018-03-19 14:03:23 -0700224 } while (0)
225
Yiwei Zhang7b3cbea2022-07-13 00:25:11 +0000226#define drv_loge(format, ...) _drv_log(DRV_LOGE, format, ##__VA_ARGS__)
227#define drv_logv(format, ...) _drv_log(DRV_LOGV, format, ##__VA_ARGS__)
228#define drv_logd(format, ...) _drv_log(DRV_LOGD, format, ##__VA_ARGS__)
229#define drv_logi(format, ...) _drv_log(DRV_LOGI, format, ##__VA_ARGS__)
230
Yiwei Zhang7b3cbea2022-07-13 00:25:11 +0000231__attribute__((format(printf, 5, 6))) void drv_log_prefix(enum drv_log_level level,
232 const char *prefix, const char *file,
Alistair Strachan0cfaaa52018-03-19 14:03:23 -0700233 int line, const char *format, ...);
234
Gurchetan Singh46faf6b2016-08-05 14:40:07 -0700235#ifdef __cplusplus
236}
237#endif
238
239#endif