OSDN Git Service

gralloc0_register_buffer: initialize gralloc0 when needed
[android-x86/external-minigbm.git] / vgem.c
1 /*
2  * Copyright 2016 The Chromium OS Authors. All rights reserved.
3  * Use of this source code is governed by a BSD-style license that can be
4  * found in the LICENSE file.
5  */
6
7 #include "drv_priv.h"
8 #include "helpers.h"
9 #include "util.h"
10
11 #define MESA_LLVMPIPE_TILE_ORDER 6
12 #define MESA_LLVMPIPE_TILE_SIZE (1 << MESA_LLVMPIPE_TILE_ORDER)
13
14 static const uint32_t render_target_formats[] = { DRM_FORMAT_ABGR8888, DRM_FORMAT_ARGB8888,
15                                                   DRM_FORMAT_RGB565, DRM_FORMAT_XBGR8888,
16                                                   DRM_FORMAT_XRGB8888 };
17
18 static const uint32_t texture_source_formats[] = { DRM_FORMAT_R8, DRM_FORMAT_YVU420,
19                                                    DRM_FORMAT_YVU420_ANDROID };
20
21 static int vgem_init(struct driver *drv)
22 {
23         int ret;
24         ret = drv_add_combinations(drv, render_target_formats, ARRAY_SIZE(render_target_formats),
25                                    &LINEAR_METADATA, BO_USE_RENDER_MASK);
26         if (ret)
27                 return ret;
28
29         ret = drv_add_combinations(drv, texture_source_formats, ARRAY_SIZE(texture_source_formats),
30                                    &LINEAR_METADATA, BO_USE_TEXTURE_MASK);
31         if (ret)
32                 return ret;
33
34         return drv_modify_linear_combinations(drv);
35 }
36
37 static int vgem_bo_create(struct bo *bo, uint32_t width, uint32_t height, uint32_t format,
38                           uint64_t flags)
39 {
40         width = ALIGN(width, MESA_LLVMPIPE_TILE_SIZE);
41         height = ALIGN(height, MESA_LLVMPIPE_TILE_SIZE);
42
43         /* HAL_PIXEL_FORMAT_YV12 requires that the buffer's height not be aligned. */
44         if (bo->format == DRM_FORMAT_YVU420_ANDROID)
45                 height = bo->height;
46
47         return drv_dumb_bo_create(bo, width, height, format, flags);
48 }
49
50 static uint32_t vgem_resolve_format(uint32_t format, uint64_t flags)
51 {
52         switch (format) {
53         case DRM_FORMAT_FLEX_IMPLEMENTATION_DEFINED:
54                 /*HACK: See b/28671744 */
55                 return DRM_FORMAT_XBGR8888;
56         case DRM_FORMAT_FLEX_YCbCr_420_888:
57                 return DRM_FORMAT_YVU420;
58         default:
59                 return format;
60         }
61 }
62
63 struct backend backend_vgem = {
64         .name = "vgem",
65         .init = vgem_init,
66         .bo_create = vgem_bo_create,
67         .bo_destroy = drv_dumb_bo_destroy,
68         .bo_import = drv_prime_bo_import,
69         .bo_map = drv_dumb_bo_map,
70         .bo_unmap = drv_bo_munmap,
71         .resolve_format = vgem_resolve_format,
72 };