xref: /aosp_15_r20/external/drm_hwcomposer/bufferinfo/legacy/BufferInfoMaliHisi.cpp (revision 0a9764fe0a15e71ebbeb85e87e10990c23aab47f)
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