1 /*
2 * Copyright Samsung Electronics Co.,LTD.
3 * Copyright (C) 2016 The Android Open Source Project
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18 #include <log/log.h>
19 #include <mali_gralloc_formats.h>
20 #include <exynos_format.h> // hardware/smasung_slsi/exynos/include
21
22 #include <cstring>
23
24 #include "acrylic_g2d.h"
25 #include "acrylic_internal.h"
26
27 static uint32_t all_fimg2d_gs101_formats[] = {
28 HAL_PIXEL_FORMAT_RGBA_8888,
29 HAL_PIXEL_FORMAT_BGRA_8888,
30 HAL_PIXEL_FORMAT_RGBA_1010102,
31 HAL_PIXEL_FORMAT_RGBX_8888,
32 HAL_PIXEL_FORMAT_RGB_888,
33 HAL_PIXEL_FORMAT_RGB_565,
34 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_P,
35 HAL_PIXEL_FORMAT_YCrCb_420_SP, // NV21 (YVU420 semi-planar)
36 HAL_PIXEL_FORMAT_EXYNOS_YCrCb_420_SP_M, // NV21 on multi-buffer
37 HAL_PIXEL_FORMAT_EXYNOS_YCrCb_420_SP_M_FULL, // NV21 on multi-buffer
38 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP, // NV12 (YUV420 semi-planar)
39 HAL_PIXEL_FORMAT_GOOGLE_NV12_SP, // NV12 (YUV420 semi-planar)
40 MALI_GRALLOC_FORMAT_INTERNAL_YUV420_8BIT_I, // NV12 AFBC
41 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN, // NV12 with MFC alignment constraints
42 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M, // NV12M with MFC alignment constraints on multi-buffer
43 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_PRIV, // NV12M with MFC alignment constraints on multi-buffer
44 HAL_PIXEL_FORMAT_YCbCr_422_SP, // YUV422 2P (YUV422 semi-planar)
45 HAL_PIXEL_FORMAT_YCBCR_P010,
46 HAL_PIXEL_FORMAT_GOOGLE_NV12_SP_10B,
47 MALI_GRALLOC_FORMAT_INTERNAL_YUV420_10BIT_I,
48 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_P010_M,
49 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_SBWC,
50 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_SBWC,
51 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_10B_SBWC,
52 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_10B_SBWC,
53 HAL_PIXEL_FORMAT_EXYNOS_YCrCb_420_SP_M_SBWC,
54 HAL_PIXEL_FORMAT_EXYNOS_YCrCb_420_SP_M_10B_SBWC,
55 };
56
57 static uint32_t all_fimg2d_gs201_formats[] = {
58 HAL_PIXEL_FORMAT_RGBA_8888,
59 HAL_PIXEL_FORMAT_BGRA_8888,
60 HAL_PIXEL_FORMAT_RGBA_1010102,
61 HAL_PIXEL_FORMAT_RGBX_8888,
62 HAL_PIXEL_FORMAT_RGB_888,
63 HAL_PIXEL_FORMAT_RGB_565,
64 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_P,
65 HAL_PIXEL_FORMAT_YCrCb_420_SP, // NV21 (YVU420 semi-planar)
66 HAL_PIXEL_FORMAT_EXYNOS_YCrCb_420_SP_M, // NV21 on multi-buffer
67 HAL_PIXEL_FORMAT_EXYNOS_YCrCb_420_SP_M_FULL, // NV21 on multi-buffer
68 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP, // NV12 (YUV420 semi-planar)
69 HAL_PIXEL_FORMAT_GOOGLE_NV12_SP, // NV12 (YUV420 semi-planar)
70 MALI_GRALLOC_FORMAT_INTERNAL_YUV420_8BIT_I, // NV12 AFBC
71 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN, // NV12 with MFC alignment constraints
72 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M, // NV12M with MFC alignment constraints on multi-buffer
73 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_PRIV, // NV12M with MFC alignment constraints on multi-buffer
74 HAL_PIXEL_FORMAT_YCbCr_422_SP, // YUV422 2P (YUV422 semi-planar)
75 HAL_PIXEL_FORMAT_YCBCR_P010,
76 HAL_PIXEL_FORMAT_GOOGLE_NV12_SP_10B,
77 MALI_GRALLOC_FORMAT_INTERNAL_YUV420_10BIT_I,
78 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_P010_M,
79 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_SBWC,
80 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_SBWC,
81 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_10B_SBWC,
82 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_10B_SBWC,
83 HAL_PIXEL_FORMAT_EXYNOS_YCrCb_420_SP_M_SBWC,
84 HAL_PIXEL_FORMAT_EXYNOS_YCrCb_420_SP_M_10B_SBWC,
85 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_SBWC_L50,
86 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_SBWC_L75,
87 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_SBWC_L50,
88 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_SBWC_L75,
89 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_10B_SBWC_L40,
90 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_10B_SBWC_L60,
91 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SP_M_10B_SBWC_L80,
92 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_10B_SBWC_L40,
93 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_10B_SBWC_L60,
94 HAL_PIXEL_FORMAT_EXYNOS_YCbCr_420_SPN_10B_SBWC_L80,
95 };
96
97 // The presence of the dataspace definitions are in the order
98 // of application's preference to reduce comparations.
99 static int all_hwc_dataspaces[] = {
100 HAL_DATASPACE_STANDARD_BT709,
101 HAL_DATASPACE_STANDARD_BT709 | HAL_DATASPACE_RANGE_FULL,
102 HAL_DATASPACE_STANDARD_BT709 | HAL_DATASPACE_RANGE_LIMITED,
103 HAL_DATASPACE_STANDARD_BT2020,
104 HAL_DATASPACE_STANDARD_BT2020 | HAL_DATASPACE_RANGE_FULL,
105 HAL_DATASPACE_STANDARD_BT2020 | HAL_DATASPACE_RANGE_LIMITED,
106 HAL_DATASPACE_STANDARD_BT601_625,
107 HAL_DATASPACE_STANDARD_BT601_625 | HAL_DATASPACE_RANGE_FULL,
108 HAL_DATASPACE_STANDARD_BT601_625 | HAL_DATASPACE_RANGE_LIMITED,
109 HAL_DATASPACE_STANDARD_BT601_525,
110 HAL_DATASPACE_STANDARD_BT601_525 | HAL_DATASPACE_RANGE_FULL,
111 HAL_DATASPACE_STANDARD_BT601_525 | HAL_DATASPACE_RANGE_LIMITED,
112 HAL_DATASPACE_STANDARD_BT601_625_UNADJUSTED,
113 HAL_DATASPACE_STANDARD_BT601_625_UNADJUSTED | HAL_DATASPACE_RANGE_FULL,
114 HAL_DATASPACE_STANDARD_BT601_625_UNADJUSTED | HAL_DATASPACE_RANGE_LIMITED,
115 HAL_DATASPACE_STANDARD_BT601_525_UNADJUSTED,
116 HAL_DATASPACE_STANDARD_BT601_525_UNADJUSTED | HAL_DATASPACE_RANGE_FULL,
117 HAL_DATASPACE_STANDARD_BT601_525_UNADJUSTED | HAL_DATASPACE_RANGE_LIMITED,
118 HAL_DATASPACE_STANDARD_DCI_P3,
119 HAL_DATASPACE_STANDARD_DCI_P3 | HAL_DATASPACE_RANGE_FULL,
120 HAL_DATASPACE_STANDARD_DCI_P3 | HAL_DATASPACE_RANGE_LIMITED,
121 HAL_DATASPACE_STANDARD_FILM,
122 HAL_DATASPACE_STANDARD_FILM | HAL_DATASPACE_RANGE_FULL,
123 HAL_DATASPACE_STANDARD_FILM | HAL_DATASPACE_RANGE_LIMITED,
124 // 0 should be treated as BT709 Limited range
125 0,
126 HAL_DATASPACE_RANGE_FULL,
127 HAL_DATASPACE_RANGE_LIMITED,
128 // Depricated legacy dataspace definitions
129 HAL_DATASPACE_SRGB,
130 HAL_DATASPACE_JFIF,
131 HAL_DATASPACE_BT601_525,
132 HAL_DATASPACE_BT601_625,
133 HAL_DATASPACE_BT709,
134 };
135
136 const static stHW2DCapability __capability_fimg2d_gs101 = {
137 .max_upsampling_num = {8, 8},
138 .max_downsampling_factor = {4, 4},
139 .max_upsizing_num = {8, 8},
140 .max_downsizing_factor = {4, 4},
141 .min_src_dimension = {1, 1},
142 .max_src_dimension = {8192, 8192},
143 .min_dst_dimension = {1, 1},
144 .max_dst_dimension = {8192, 8192},
145 .min_pix_align = {1, 1},
146 .rescaling_count = 0,
147 .compositing_mode = HW2DCapability::BLEND_NONE | HW2DCapability::BLEND_SRC_COPY | HW2DCapability::BLEND_SRC_OVER,
148 .transform_type = HW2DCapability::TRANSFORM_ALL,
149 .auxiliary_feature = HW2DCapability::FEATURE_PLANE_ALPHA | HW2DCapability::FEATURE_UORDER_WRITE
150 | HW2DCapability::FEATURE_AFBC_ENCODE | HW2DCapability::FEATURE_AFBC_DECODE
151 | HW2DCapability::FEATURE_SOLIDCOLOR,
152 .num_formats = ARRSIZE(all_fimg2d_gs101_formats),
153 .num_dataspaces = ARRSIZE(all_hwc_dataspaces),
154 .max_layers = 4,
155 .pixformats = all_fimg2d_gs101_formats,
156 .dataspaces = all_hwc_dataspaces,
157 .base_align = 1,
158 };
159
160 const static stHW2DCapability __capability_fimg2d_gs201 = {
161 .max_upsampling_num = {8, 8},
162 .max_downsampling_factor = {4, 4},
163 .max_upsizing_num = {8, 8},
164 .max_downsizing_factor = {4, 4},
165 .min_src_dimension = {1, 1},
166 .max_src_dimension = {8192, 8192},
167 .min_dst_dimension = {1, 1},
168 .max_dst_dimension = {8192, 8192},
169 .min_pix_align = {1, 1},
170 .rescaling_count = 0,
171 .compositing_mode = HW2DCapability::BLEND_NONE | HW2DCapability::BLEND_SRC_COPY | HW2DCapability::BLEND_SRC_OVER,
172 .transform_type = HW2DCapability::TRANSFORM_ALL,
173 .auxiliary_feature = HW2DCapability::FEATURE_PLANE_ALPHA | HW2DCapability::FEATURE_UORDER_WRITE
174 | HW2DCapability::FEATURE_AFBC_ENCODE | HW2DCapability::FEATURE_AFBC_DECODE
175 | HW2DCapability::FEATURE_SOLIDCOLOR,
176 .num_formats = ARRSIZE(all_fimg2d_gs201_formats),
177 .num_dataspaces = ARRSIZE(all_hwc_dataspaces),
178 .max_layers = 4,
179 .pixformats = all_fimg2d_gs201_formats,
180 .dataspaces = all_hwc_dataspaces,
181 .base_align = 1,
182 };
183
184 static const HW2DCapability capability_fimg2d_gs101(__capability_fimg2d_gs101);
185
186 static const HW2DCapability capability_fimg2d_gs201(__capability_fimg2d_gs201);
187
createInstance(const char * spec)188 Acrylic *Acrylic::createInstance(const char *spec)
189 {
190 Acrylic *compositor = nullptr;
191
192 ALOGD_TEST("Creating a new Acrylic instance of '%s'", spec);
193
194 if (strcmp(spec, "fimg2d_gs101") == 0) {
195 compositor = new AcrylicCompositorG2D(capability_fimg2d_gs101, true);
196 } else if (strcmp(spec, "fimg2d_gs201") == 0) {
197 compositor = new AcrylicCompositorG2D(capability_fimg2d_gs201, true);
198 } else {
199 ALOGE("Unknown HW2D compositor spec., %s", spec);
200 return nullptr;
201 }
202
203 ALOGE_IF(!compositor, "Failed to create HW2D compositor of '%s'", spec);
204
205 return compositor;
206 }
207
createCompositor()208 Acrylic *Acrylic::createCompositor()
209 {
210 return Acrylic::createInstance(LIBACRYL_DEFAULT_COMPOSITOR);
211 }
212
createScaler()213 Acrylic *Acrylic::createScaler()
214 {
215 return Acrylic::createInstance(LIBACRYL_DEFAULT_SCALER);
216 }
217
createBlter()218 Acrylic *Acrylic::createBlter()
219 {
220 return Acrylic::createInstance(LIBACRYL_DEFAULT_BLTER);
221 }
222
createAcrylic(const char * spec)223 Acrylic *AcrylicFactory::createAcrylic(const char *spec)
224 {
225 if (strcmp(spec, "default_compositor") == 0) {
226 spec = LIBACRYL_DEFAULT_COMPOSITOR;
227 } else if (strcmp(spec, "default_scaler") == 0) {
228 spec = LIBACRYL_DEFAULT_SCALER;
229 } else if (strcmp(spec, "default_blter") == 0) {
230 spec = LIBACRYL_DEFAULT_BLTER;
231 }
232
233 return Acrylic::createInstance(spec);
234 }
235