blob: 10ada0b393ba191c220a859e2468199baf95de03 [file] [log] [blame]
Rajesh Yadav7f79cb52018-01-22 18:29:06 +05301/*
2 * Copyright 2018 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#ifdef DRV_MSM
8
9#include "drv_priv.h"
10#include "helpers.h"
11#include "util.h"
12
Stéphane Marchesin23e006a2018-02-28 16:37:46 -080013#define MESA_LLVMPIPE_TILE_ORDER 6
14#define MESA_LLVMPIPE_TILE_SIZE (1 << MESA_LLVMPIPE_TILE_ORDER)
15
Gurchetan Singhb131c9d2018-08-28 14:17:05 -070016static const uint32_t render_target_formats[] = { DRM_FORMAT_ABGR8888, DRM_FORMAT_ARGB8888,
Gurchetan Singh71bc6652018-09-17 17:42:05 -070017 DRM_FORMAT_RGB565, DRM_FORMAT_XBGR8888,
18 DRM_FORMAT_XRGB8888 };
Rajesh Yadav7f79cb52018-01-22 18:29:06 +053019
Gurchetan Singhb131c9d2018-08-28 14:17:05 -070020static const uint32_t supported_formats[] = { DRM_FORMAT_NV12, DRM_FORMAT_R8, DRM_FORMAT_YVU420,
21 DRM_FORMAT_YVU420_ANDROID };
Alexandre Courbot1805a9b2018-05-21 19:05:10 +090022
Rajesh Yadav7f79cb52018-01-22 18:29:06 +053023static int msm_init(struct driver *drv)
24{
25 drv_add_combinations(drv, render_target_formats, ARRAY_SIZE(render_target_formats),
26 &LINEAR_METADATA, BO_USE_RENDER_MASK);
27
Alexandre Courbot1805a9b2018-05-21 19:05:10 +090028 drv_add_combinations(drv, supported_formats, ARRAY_SIZE(supported_formats),
29 &LINEAR_METADATA, BO_USE_TEXTURE_MASK | BO_USE_HW_VIDEO_DECODER);
30
Gurchetan Singh71bc6652018-09-17 17:42:05 -070031 /* Android CTS tests require this. */
32 drv_add_combination(drv, DRM_FORMAT_BGR888, &LINEAR_METADATA, BO_USE_SW_MASK);
33
Rajesh Yadav7f79cb52018-01-22 18:29:06 +053034 return drv_modify_linear_combinations(drv);
35}
36
Stéphane Marchesin23e006a2018-02-28 16:37:46 -080037static int msm_bo_create(struct bo *bo, uint32_t width, uint32_t height, uint32_t format,
Alistair Strachan0cfaaa52018-03-19 14:03:23 -070038 uint64_t flags)
Stéphane Marchesin23e006a2018-02-28 16:37:46 -080039{
40 width = ALIGN(width, MESA_LLVMPIPE_TILE_SIZE);
41 height = ALIGN(height, MESA_LLVMPIPE_TILE_SIZE);
42
Keiichi Watanabeaf94db92018-08-06 18:37:21 +090043 /*
44 * The extra 12KB at the end are a requirement of the Venus codec driver.
45 * Since |height| will be multiplied by 3/2 in drv_dumb_bo_create,
46 * we multiply this padding by 2/3 here.
47 */
Alexandre Courbot1805a9b2018-05-21 19:05:10 +090048 if (bo->format == DRM_FORMAT_NV12)
Keiichi Watanabeaf94db92018-08-06 18:37:21 +090049 height += 2 * DIV_ROUND_UP(0x3000, 3 * width);
Alexandre Courbot1805a9b2018-05-21 19:05:10 +090050
Stéphane Marchesin23e006a2018-02-28 16:37:46 -080051 return drv_dumb_bo_create(bo, width, height, format, flags);
52}
53
Rajesh Yadav7f79cb52018-01-22 18:29:06 +053054const struct backend backend_msm = {
55 .name = "msm",
56 .init = msm_init,
Stéphane Marchesin23e006a2018-02-28 16:37:46 -080057 .bo_create = msm_bo_create,
Rajesh Yadav7f79cb52018-01-22 18:29:06 +053058 .bo_destroy = drv_dumb_bo_destroy,
59 .bo_import = drv_prime_bo_import,
60 .bo_map = drv_dumb_bo_map,
61 .bo_unmap = drv_bo_munmap,
62};
63
64#endif /* DRV_MSM */