blob: 0f3d2e3e0e3f9c20830cc2dda3461dc21c362e17 [file] [log] [blame]
Gurchetan Singh5521bde2016-09-30 14:53:32 -07001/*
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"
Gurchetan Singh179687e2016-10-28 10:07:35 -07009#include "util.h"
10
Gurchetan Singhebe1e952016-11-29 20:36:13 -080011#define MESA_LLVMPIPE_TILE_ORDER 6
12#define MESA_LLVMPIPE_TILE_SIZE (1 << MESA_LLVMPIPE_TILE_ORDER)
13
Gurchetan Singh45de1992016-12-02 12:32:16 -080014static struct supported_combination combos[4] = {
Gurchetan Singh179687e2016-10-28 10:07:35 -070015 {DRM_FORMAT_ABGR8888, DRM_FORMAT_MOD_NONE,
Gurchetan Singh6f6e18a2016-12-19 15:14:18 -080016 BO_USE_CURSOR | BO_USE_LINEAR | BO_USE_RENDERING | BO_USE_SW_READ_OFTEN |
17 BO_USE_SW_WRITE_OFTEN | BO_USE_SW_READ_RARELY | BO_USE_SW_WRITE_RARELY},
Gurchetan Singh45de1992016-12-02 12:32:16 -080018 {DRM_FORMAT_RGB565, DRM_FORMAT_MOD_NONE,
Gurchetan Singh6f6e18a2016-12-19 15:14:18 -080019 BO_USE_LINEAR | BO_USE_RENDERING | BO_USE_SW_READ_OFTEN | BO_USE_SW_WRITE_OFTEN |
Gurchetan Singh45de1992016-12-02 12:32:16 -080020 BO_USE_SW_READ_RARELY | BO_USE_SW_WRITE_RARELY},
Gurchetan Singh6f6e18a2016-12-19 15:14:18 -080021 {DRM_FORMAT_XBGR8888, DRM_FORMAT_MOD_NONE,
22 BO_USE_CURSOR | BO_USE_LINEAR | BO_USE_RENDERING | BO_USE_SW_READ_OFTEN |
23 BO_USE_SW_WRITE_OFTEN | BO_USE_SW_READ_RARELY | BO_USE_SW_WRITE_RARELY},
Gurchetan Singh179687e2016-10-28 10:07:35 -070024 {DRM_FORMAT_YVU420, DRM_FORMAT_MOD_NONE,
Gurchetan Singh6f6e18a2016-12-19 15:14:18 -080025 BO_USE_LINEAR | BO_USE_RENDERING | BO_USE_SW_READ_OFTEN | BO_USE_SW_WRITE_OFTEN |
26 BO_USE_SW_READ_RARELY | BO_USE_SW_WRITE_RARELY},
Gurchetan Singh179687e2016-10-28 10:07:35 -070027};
28
29static int vgem_init(struct driver *drv)
30{
31 drv_insert_combinations(drv, combos, ARRAY_SIZE(combos));
Gurchetan Singh714c6892016-12-02 11:02:47 -080032 return 0;
Gurchetan Singh179687e2016-10-28 10:07:35 -070033}
Gurchetan Singh5521bde2016-09-30 14:53:32 -070034
Gurchetan Singhebe1e952016-11-29 20:36:13 -080035static int vgem_bo_create(struct bo *bo, uint32_t width, uint32_t height,
36 uint32_t format, uint32_t flags)
37{
38 int ret = drv_dumb_bo_create(bo, ALIGN(width, MESA_LLVMPIPE_TILE_SIZE),
39 ALIGN(height, MESA_LLVMPIPE_TILE_SIZE),
40 format, flags);
41 bo->width = width;
42 bo->height = height;
43
44 return ret;
45}
46
Gurchetan Singhf3b22da2016-11-21 10:46:38 -080047static uint32_t vgem_resolve_format(uint32_t format)
Gurchetan Singh5521bde2016-09-30 14:53:32 -070048{
49 switch (format) {
Gurchetan Singhf3b22da2016-11-21 10:46:38 -080050 case DRM_FORMAT_FLEX_IMPLEMENTATION_DEFINED:
Gurchetan Singh5521bde2016-09-30 14:53:32 -070051 /*HACK: See b/28671744 */
Gurchetan Singhf3b22da2016-11-21 10:46:38 -080052 return DRM_FORMAT_XBGR8888;
53 case DRM_FORMAT_FLEX_YCbCr_420_888:
54 return DRM_FORMAT_YVU420;
Gurchetan Singh5521bde2016-09-30 14:53:32 -070055 default:
56 return format;
57 }
58}
59
Gurchetan Singh179687e2016-10-28 10:07:35 -070060struct backend backend_vgem =
Gurchetan Singh5521bde2016-09-30 14:53:32 -070061{
62 .name = "vgem",
Gurchetan Singh179687e2016-10-28 10:07:35 -070063 .init = vgem_init,
Gurchetan Singhebe1e952016-11-29 20:36:13 -080064 .bo_create = vgem_bo_create,
Gurchetan Singh5521bde2016-09-30 14:53:32 -070065 .bo_destroy = drv_dumb_bo_destroy,
Gurchetan Singh71611d62017-01-03 16:49:56 -080066 .bo_import = drv_prime_bo_import,
Gurchetan Singh5521bde2016-09-30 14:53:32 -070067 .bo_map = drv_dumb_bo_map,
68 .resolve_format = vgem_resolve_format,
Gurchetan Singh5521bde2016-09-30 14:53:32 -070069};
70