1*0a9764feSAndroid Build Coastguard Worker /*
2*0a9764feSAndroid Build Coastguard Worker * Copyright (C) 2020 The Android Open Source Project
3*0a9764feSAndroid Build Coastguard Worker *
4*0a9764feSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*0a9764feSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*0a9764feSAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*0a9764feSAndroid Build Coastguard Worker *
8*0a9764feSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
9*0a9764feSAndroid Build Coastguard Worker *
10*0a9764feSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*0a9764feSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*0a9764feSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*0a9764feSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*0a9764feSAndroid Build Coastguard Worker * limitations under the License.
15*0a9764feSAndroid Build Coastguard Worker */
16*0a9764feSAndroid Build Coastguard Worker
17*0a9764feSAndroid Build Coastguard Worker #define LOG_TAG "drmhwc"
18*0a9764feSAndroid Build Coastguard Worker
19*0a9764feSAndroid Build Coastguard Worker #include "BufferInfoMaliHisi.h"
20*0a9764feSAndroid Build Coastguard Worker
21*0a9764feSAndroid Build Coastguard Worker #include <xf86drm.h>
22*0a9764feSAndroid Build Coastguard Worker #include <xf86drmMode.h>
23*0a9764feSAndroid Build Coastguard Worker
24*0a9764feSAndroid Build Coastguard Worker #include <cinttypes>
25*0a9764feSAndroid Build Coastguard Worker
26*0a9764feSAndroid Build Coastguard Worker #include "gralloc_priv.h"
27*0a9764feSAndroid Build Coastguard Worker #include "utils/log.h"
28*0a9764feSAndroid Build Coastguard Worker
29*0a9764feSAndroid Build Coastguard Worker #define MALI_ALIGN(value, base) (((value) + ((base)-1)) & ~((base)-1))
30*0a9764feSAndroid Build Coastguard Worker
31*0a9764feSAndroid Build Coastguard Worker namespace android {
32*0a9764feSAndroid Build Coastguard Worker
33*0a9764feSAndroid Build Coastguard Worker LEGACY_BUFFER_INFO_GETTER(BufferInfoMaliHisi);
34*0a9764feSAndroid Build Coastguard Worker
35*0a9764feSAndroid Build Coastguard Worker #if defined(MALI_GRALLOC_INTFMT_AFBC_BASIC) && \
36*0a9764feSAndroid Build Coastguard Worker defined(AFBC_FORMAT_MOD_BLOCK_SIZE_16x16)
ConvertGrallocFormatToDrmModifiers(uint64_t flags,bool is_rgb)37*0a9764feSAndroid Build Coastguard Worker uint64_t BufferInfoMaliHisi::ConvertGrallocFormatToDrmModifiers(uint64_t flags,
38*0a9764feSAndroid Build Coastguard Worker bool is_rgb) {
39*0a9764feSAndroid Build Coastguard Worker uint64_t features = 0UL;
40*0a9764feSAndroid Build Coastguard Worker
41*0a9764feSAndroid Build Coastguard Worker if (flags & MALI_GRALLOC_INTFMT_AFBC_BASIC)
42*0a9764feSAndroid Build Coastguard Worker features |= AFBC_FORMAT_MOD_BLOCK_SIZE_16x16;
43*0a9764feSAndroid Build Coastguard Worker
44*0a9764feSAndroid Build Coastguard Worker if (flags & MALI_GRALLOC_INTFMT_AFBC_SPLITBLK)
45*0a9764feSAndroid Build Coastguard Worker features |= (AFBC_FORMAT_MOD_SPLIT | AFBC_FORMAT_MOD_SPARSE);
46*0a9764feSAndroid Build Coastguard Worker
47*0a9764feSAndroid Build Coastguard Worker if (flags & MALI_GRALLOC_INTFMT_AFBC_WIDEBLK)
48*0a9764feSAndroid Build Coastguard Worker features |= AFBC_FORMAT_MOD_BLOCK_SIZE_32x8;
49*0a9764feSAndroid Build Coastguard Worker
50*0a9764feSAndroid Build Coastguard Worker if (flags & MALI_GRALLOC_INTFMT_AFBC_TILED_HEADERS)
51*0a9764feSAndroid Build Coastguard Worker features |= AFBC_FORMAT_MOD_TILED;
52*0a9764feSAndroid Build Coastguard Worker
53*0a9764feSAndroid Build Coastguard Worker if (features) {
54*0a9764feSAndroid Build Coastguard Worker if (is_rgb)
55*0a9764feSAndroid Build Coastguard Worker features |= AFBC_FORMAT_MOD_YTR;
56*0a9764feSAndroid Build Coastguard Worker
57*0a9764feSAndroid Build Coastguard Worker return DRM_FORMAT_MOD_ARM_AFBC(features);
58*0a9764feSAndroid Build Coastguard Worker }
59*0a9764feSAndroid Build Coastguard Worker
60*0a9764feSAndroid Build Coastguard Worker return 0;
61*0a9764feSAndroid Build Coastguard Worker }
62*0a9764feSAndroid Build Coastguard Worker #else
ConvertGrallocFormatToDrmModifiers(uint64_t,bool)63*0a9764feSAndroid Build Coastguard Worker uint64_t BufferInfoMaliHisi::ConvertGrallocFormatToDrmModifiers(
64*0a9764feSAndroid Build Coastguard Worker uint64_t /* flags */, bool /* is_rgb */) {
65*0a9764feSAndroid Build Coastguard Worker return 0;
66*0a9764feSAndroid Build Coastguard Worker }
67*0a9764feSAndroid Build Coastguard Worker #endif
68*0a9764feSAndroid Build Coastguard Worker
GetBoInfo(buffer_handle_t handle)69*0a9764feSAndroid Build Coastguard Worker auto BufferInfoMaliHisi::GetBoInfo(buffer_handle_t handle)
70*0a9764feSAndroid Build Coastguard Worker -> std::optional<BufferInfo> {
71*0a9764feSAndroid Build Coastguard Worker bool is_rgb = false;
72*0a9764feSAndroid Build Coastguard Worker
73*0a9764feSAndroid Build Coastguard Worker const auto *hnd = (private_handle_t const *)handle;
74*0a9764feSAndroid Build Coastguard Worker if (!hnd)
75*0a9764feSAndroid Build Coastguard Worker return {};
76*0a9764feSAndroid Build Coastguard Worker
77*0a9764feSAndroid Build Coastguard Worker if (!(hnd->usage & GRALLOC_USAGE_HW_FB))
78*0a9764feSAndroid Build Coastguard Worker return {};
79*0a9764feSAndroid Build Coastguard Worker
80*0a9764feSAndroid Build Coastguard Worker const uint32_t fmt = ConvertHalFormatToDrm(hnd->req_format);
81*0a9764feSAndroid Build Coastguard Worker if (fmt == DRM_FORMAT_INVALID)
82*0a9764feSAndroid Build Coastguard Worker return {};
83*0a9764feSAndroid Build Coastguard Worker
84*0a9764feSAndroid Build Coastguard Worker BufferInfo bi{};
85*0a9764feSAndroid Build Coastguard Worker
86*0a9764feSAndroid Build Coastguard Worker is_rgb = IsDrmFormatRgb(fmt);
87*0a9764feSAndroid Build Coastguard Worker bi.modifiers[0] = ConvertGrallocFormatToDrmModifiers(hnd->internal_format,
88*0a9764feSAndroid Build Coastguard Worker is_rgb);
89*0a9764feSAndroid Build Coastguard Worker
90*0a9764feSAndroid Build Coastguard Worker bi.width = hnd->width;
91*0a9764feSAndroid Build Coastguard Worker bi.height = hnd->height;
92*0a9764feSAndroid Build Coastguard Worker bi.format = fmt;
93*0a9764feSAndroid Build Coastguard Worker bi.pitches[0] = hnd->byte_stride;
94*0a9764feSAndroid Build Coastguard Worker bi.prime_fds[0] = hnd->share_fd;
95*0a9764feSAndroid Build Coastguard Worker bi.offsets[0] = 0;
96*0a9764feSAndroid Build Coastguard Worker
97*0a9764feSAndroid Build Coastguard Worker switch (fmt) {
98*0a9764feSAndroid Build Coastguard Worker case DRM_FORMAT_YVU420: {
99*0a9764feSAndroid Build Coastguard Worker int align = 128;
100*0a9764feSAndroid Build Coastguard Worker if (hnd->usage &
101*0a9764feSAndroid Build Coastguard Worker (GRALLOC_USAGE_SW_READ_MASK | GRALLOC_USAGE_SW_WRITE_MASK))
102*0a9764feSAndroid Build Coastguard Worker align = 16;
103*0a9764feSAndroid Build Coastguard Worker const int adjusted_height = MALI_ALIGN(hnd->height, 2);
104*0a9764feSAndroid Build Coastguard Worker const int y_size = adjusted_height * hnd->byte_stride;
105*0a9764feSAndroid Build Coastguard Worker const int vu_stride = MALI_ALIGN(hnd->byte_stride / 2, align);
106*0a9764feSAndroid Build Coastguard Worker const int v_size = vu_stride * (adjusted_height / 2);
107*0a9764feSAndroid Build Coastguard Worker
108*0a9764feSAndroid Build Coastguard Worker /* V plane*/
109*0a9764feSAndroid Build Coastguard Worker bi.prime_fds[1] = hnd->share_fd;
110*0a9764feSAndroid Build Coastguard Worker bi.pitches[1] = vu_stride;
111*0a9764feSAndroid Build Coastguard Worker bi.offsets[1] = y_size;
112*0a9764feSAndroid Build Coastguard Worker /* U plane */
113*0a9764feSAndroid Build Coastguard Worker bi.prime_fds[2] = hnd->share_fd;
114*0a9764feSAndroid Build Coastguard Worker bi.pitches[2] = vu_stride;
115*0a9764feSAndroid Build Coastguard Worker bi.offsets[2] = y_size + v_size;
116*0a9764feSAndroid Build Coastguard Worker break;
117*0a9764feSAndroid Build Coastguard Worker }
118*0a9764feSAndroid Build Coastguard Worker default:
119*0a9764feSAndroid Build Coastguard Worker break;
120*0a9764feSAndroid Build Coastguard Worker }
121*0a9764feSAndroid Build Coastguard Worker
122*0a9764feSAndroid Build Coastguard Worker return bi;
123*0a9764feSAndroid Build Coastguard Worker }
124*0a9764feSAndroid Build Coastguard Worker
125*0a9764feSAndroid Build Coastguard Worker } // namespace android
126