Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(856)

Side by Side Diff: ui/ozone/gl/gl_image_ozone_native_pixmap.cc

Issue 2122573003: media: replace LUMINANCE_F16 by RG_88 for 9/10-bit h264 videos Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: introduce --disable-half-float-conversion-texture flag Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ui/ozone/gl/gl_image_ozone_native_pixmap.h" 5 #include "ui/ozone/gl/gl_image_ozone_native_pixmap.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "ui/gfx/buffer_format_util.h" 9 #include "ui/gfx/buffer_format_util.h"
10 #include "ui/gl/gl_surface_egl.h" 10 #include "ui/gl/gl_surface_egl.h"
11 11
12 #define FOURCC(a, b, c, d) \ 12 #define FOURCC(a, b, c, d) \
13 ((static_cast<uint32_t>(a)) | (static_cast<uint32_t>(b) << 8) | \ 13 ((static_cast<uint32_t>(a)) | (static_cast<uint32_t>(b) << 8) | \
14 (static_cast<uint32_t>(c) << 16) | (static_cast<uint32_t>(d) << 24)) 14 (static_cast<uint32_t>(c) << 16) | (static_cast<uint32_t>(d) << 24))
15 15
16 #define DRM_FORMAT_R8 FOURCC('R', '8', ' ', ' ') 16 #define DRM_FORMAT_R8 FOURCC('R', '8', ' ', ' ')
17 #define DRM_FORMAT_GR88 FOURCC('G', 'R', '8', '8')
17 #define DRM_FORMAT_RGB565 FOURCC('R', 'G', '1', '6') 18 #define DRM_FORMAT_RGB565 FOURCC('R', 'G', '1', '6')
18 #define DRM_FORMAT_ARGB8888 FOURCC('A', 'R', '2', '4') 19 #define DRM_FORMAT_ARGB8888 FOURCC('A', 'R', '2', '4')
19 #define DRM_FORMAT_ABGR8888 FOURCC('A', 'B', '2', '4') 20 #define DRM_FORMAT_ABGR8888 FOURCC('A', 'B', '2', '4')
20 #define DRM_FORMAT_XRGB8888 FOURCC('X', 'R', '2', '4') 21 #define DRM_FORMAT_XRGB8888 FOURCC('X', 'R', '2', '4')
21 #define DRM_FORMAT_XBGR8888 FOURCC('X', 'B', '2', '4') 22 #define DRM_FORMAT_XBGR8888 FOURCC('X', 'B', '2', '4')
22 #define DRM_FORMAT_YV12 FOURCC('Y', 'V', '1', '2') 23 #define DRM_FORMAT_YV12 FOURCC('Y', 'V', '1', '2')
23 #define DRM_FORMAT_NV12 FOURCC('N', 'V', '1', '2') 24 #define DRM_FORMAT_NV12 FOURCC('N', 'V', '1', '2')
24 25
25 namespace ui { 26 namespace ui {
26 namespace { 27 namespace {
27 28
28 bool ValidInternalFormat(unsigned internalformat, gfx::BufferFormat format) { 29 bool ValidInternalFormat(unsigned internalformat, gfx::BufferFormat format) {
29 switch (internalformat) { 30 switch (internalformat) {
30 case GL_RGB: 31 case GL_RGB:
31 return format == gfx::BufferFormat::BGR_565 || 32 return format == gfx::BufferFormat::BGR_565 ||
32 format == gfx::BufferFormat::RGBX_8888 || 33 format == gfx::BufferFormat::RGBX_8888 ||
33 format == gfx::BufferFormat::BGRX_8888; 34 format == gfx::BufferFormat::BGRX_8888;
34 case GL_RGB_YCRCB_420_CHROMIUM: 35 case GL_RGB_YCRCB_420_CHROMIUM:
35 return format == gfx::BufferFormat::YVU_420; 36 return format == gfx::BufferFormat::YVU_420;
36 case GL_RGB_YCBCR_420V_CHROMIUM: 37 case GL_RGB_YCBCR_420V_CHROMIUM:
37 return format == gfx::BufferFormat::YUV_420_BIPLANAR; 38 return format == gfx::BufferFormat::YUV_420_BIPLANAR;
38 case GL_RGBA: 39 case GL_RGBA:
39 return format == gfx::BufferFormat::RGBA_8888; 40 return format == gfx::BufferFormat::RGBA_8888;
40 case GL_BGRA_EXT: 41 case GL_BGRA_EXT:
41 return format == gfx::BufferFormat::BGRA_8888; 42 return format == gfx::BufferFormat::BGRA_8888;
42 case GL_RED_EXT: 43 case GL_RED_EXT:
43 return format == gfx::BufferFormat::R_8; 44 return format == gfx::BufferFormat::R_8;
45 case GL_RG_EXT:
46 return format == gfx::BufferFormat::RG_88;
44 default: 47 default:
45 return false; 48 return false;
46 } 49 }
47 } 50 }
48 51
49 bool ValidFormat(gfx::BufferFormat format) { 52 bool ValidFormat(gfx::BufferFormat format) {
50 switch (format) { 53 switch (format) {
51 case gfx::BufferFormat::R_8: 54 case gfx::BufferFormat::R_8:
55 case gfx::BufferFormat::RG_88:
52 case gfx::BufferFormat::BGR_565: 56 case gfx::BufferFormat::BGR_565:
53 case gfx::BufferFormat::RGBA_8888: 57 case gfx::BufferFormat::RGBA_8888:
54 case gfx::BufferFormat::RGBX_8888: 58 case gfx::BufferFormat::RGBX_8888:
55 case gfx::BufferFormat::BGRA_8888: 59 case gfx::BufferFormat::BGRA_8888:
56 case gfx::BufferFormat::BGRX_8888: 60 case gfx::BufferFormat::BGRX_8888:
57 case gfx::BufferFormat::YVU_420: 61 case gfx::BufferFormat::YVU_420:
58 case gfx::BufferFormat::YUV_420_BIPLANAR: 62 case gfx::BufferFormat::YUV_420_BIPLANAR:
59 return true; 63 return true;
60 case gfx::BufferFormat::ATC: 64 case gfx::BufferFormat::ATC:
61 case gfx::BufferFormat::ATCIA: 65 case gfx::BufferFormat::ATCIA:
62 case gfx::BufferFormat::DXT1: 66 case gfx::BufferFormat::DXT1:
63 case gfx::BufferFormat::DXT5: 67 case gfx::BufferFormat::DXT5:
64 case gfx::BufferFormat::ETC1: 68 case gfx::BufferFormat::ETC1:
65 case gfx::BufferFormat::RGBA_4444: 69 case gfx::BufferFormat::RGBA_4444:
66 case gfx::BufferFormat::UYVY_422: 70 case gfx::BufferFormat::UYVY_422:
67 return false; 71 return false;
68 } 72 }
69 73
70 NOTREACHED(); 74 NOTREACHED();
71 return false; 75 return false;
72 } 76 }
73 77
74 EGLint FourCC(gfx::BufferFormat format) { 78 EGLint FourCC(gfx::BufferFormat format) {
75 switch (format) { 79 switch (format) {
76 case gfx::BufferFormat::R_8: 80 case gfx::BufferFormat::R_8:
77 return DRM_FORMAT_R8; 81 return DRM_FORMAT_R8;
82 case gfx::BufferFormat::RG_88:
83 return DRM_FORMAT_GR88;
78 case gfx::BufferFormat::BGR_565: 84 case gfx::BufferFormat::BGR_565:
79 return DRM_FORMAT_RGB565; 85 return DRM_FORMAT_RGB565;
80 case gfx::BufferFormat::RGBA_8888: 86 case gfx::BufferFormat::RGBA_8888:
81 return DRM_FORMAT_ABGR8888; 87 return DRM_FORMAT_ABGR8888;
82 case gfx::BufferFormat::RGBX_8888: 88 case gfx::BufferFormat::RGBX_8888:
83 return DRM_FORMAT_XBGR8888; 89 return DRM_FORMAT_XBGR8888;
84 case gfx::BufferFormat::BGRA_8888: 90 case gfx::BufferFormat::BGRA_8888:
85 return DRM_FORMAT_ARGB8888; 91 return DRM_FORMAT_ARGB8888;
86 case gfx::BufferFormat::BGRX_8888: 92 case gfx::BufferFormat::BGRX_8888:
87 return DRM_FORMAT_XRGB8888; 93 return DRM_FORMAT_XRGB8888;
(...skipping 192 matching lines...) Expand 10 before | Expand all | Expand 10 after
280 // TODO(ericrk): Implement GLImage OnMemoryDump. crbug.com/514914 286 // TODO(ericrk): Implement GLImage OnMemoryDump. crbug.com/514914
281 } 287 }
282 288
283 // static 289 // static
284 unsigned GLImageOzoneNativePixmap::GetInternalFormatForTesting( 290 unsigned GLImageOzoneNativePixmap::GetInternalFormatForTesting(
285 gfx::BufferFormat format) { 291 gfx::BufferFormat format) {
286 DCHECK(ValidFormat(format)); 292 DCHECK(ValidFormat(format));
287 switch (format) { 293 switch (format) {
288 case gfx::BufferFormat::R_8: 294 case gfx::BufferFormat::R_8:
289 return GL_RED_EXT; 295 return GL_RED_EXT;
296 case gfx::BufferFormat::RG_88:
297 return GL_RG_EXT;
290 case gfx::BufferFormat::BGR_565: 298 case gfx::BufferFormat::BGR_565:
291 case gfx::BufferFormat::RGBX_8888: 299 case gfx::BufferFormat::RGBX_8888:
292 case gfx::BufferFormat::BGRX_8888: 300 case gfx::BufferFormat::BGRX_8888:
293 return GL_RGB; 301 return GL_RGB;
294 case gfx::BufferFormat::RGBA_8888: 302 case gfx::BufferFormat::RGBA_8888:
295 return GL_RGBA; 303 return GL_RGBA;
296 case gfx::BufferFormat::BGRA_8888: 304 case gfx::BufferFormat::BGRA_8888:
297 return GL_BGRA_EXT; 305 return GL_BGRA_EXT;
298 case gfx::BufferFormat::ATC: 306 case gfx::BufferFormat::ATC:
299 case gfx::BufferFormat::ATCIA: 307 case gfx::BufferFormat::ATCIA:
300 case gfx::BufferFormat::DXT1: 308 case gfx::BufferFormat::DXT1:
301 case gfx::BufferFormat::DXT5: 309 case gfx::BufferFormat::DXT5:
302 case gfx::BufferFormat::ETC1: 310 case gfx::BufferFormat::ETC1:
303 case gfx::BufferFormat::RGBA_4444: 311 case gfx::BufferFormat::RGBA_4444:
304 case gfx::BufferFormat::YVU_420: 312 case gfx::BufferFormat::YVU_420:
305 case gfx::BufferFormat::YUV_420_BIPLANAR: 313 case gfx::BufferFormat::YUV_420_BIPLANAR:
306 case gfx::BufferFormat::UYVY_422: 314 case gfx::BufferFormat::UYVY_422:
307 NOTREACHED(); 315 NOTREACHED();
308 return GL_NONE; 316 return GL_NONE;
309 } 317 }
310 318
311 NOTREACHED(); 319 NOTREACHED();
312 return GL_NONE; 320 return GL_NONE;
313 } 321 }
314 322
315 } // namespace ui 323 } // namespace ui
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698