OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/gl/gl_image_linux_dma_buffer.h" | 5 #include "ui/gl/gl_image_linux_dma_buffer.h" |
6 | 6 |
7 #include <unistd.h> | 7 #include <unistd.h> |
8 | 8 |
9 #define FOURCC(a, b, c, d) \ | 9 #define FOURCC(a, b, c, d) \ |
10 ((static_cast<uint32>(a)) | (static_cast<uint32>(b) << 8) | \ | 10 ((static_cast<uint32>(a)) | (static_cast<uint32>(b) << 8) | \ |
11 (static_cast<uint32>(c) << 16) | (static_cast<uint32>(d) << 24)) | 11 (static_cast<uint32>(c) << 16) | (static_cast<uint32>(d) << 24)) |
12 | 12 |
13 #define DRM_FORMAT_ARGB8888 FOURCC('A', 'R', '2', '4') | 13 #define DRM_FORMAT_ARGB8888 FOURCC('A', 'R', '2', '4') |
14 #define DRM_FORMAT_XRGB8888 FOURCC('X', 'R', '2', '4') | 14 #define DRM_FORMAT_XRGB8888 FOURCC('X', 'R', '2', '4') |
15 | 15 |
16 namespace gfx { | 16 namespace gfx { |
17 namespace { | 17 namespace { |
18 | 18 |
19 bool ValidFormat(unsigned internalformat, gfx::GpuMemoryBuffer::Format format) { | 19 bool ValidInternalFormat(unsigned internalformat) { |
20 switch (internalformat) { | 20 switch (internalformat) { |
21 case GL_ATC_RGB_AMD: | |
22 return format == gfx::GpuMemoryBuffer::ATC; | |
23 case GL_ATC_RGBA_INTERPOLATED_ALPHA_AMD: | |
24 return format == gfx::GpuMemoryBuffer::ATCIA; | |
25 case GL_COMPRESSED_RGB_S3TC_DXT1_EXT: | |
26 return format == gfx::GpuMemoryBuffer::DXT1; | |
27 case GL_COMPRESSED_RGBA_S3TC_DXT5_EXT: | |
28 return format == gfx::GpuMemoryBuffer::DXT5; | |
29 case GL_ETC1_RGB8_OES: | |
30 return format == gfx::GpuMemoryBuffer::ETC1; | |
31 case GL_RGB: | 21 case GL_RGB: |
32 switch (format) { | |
33 case gfx::GpuMemoryBuffer::RGBX_8888: | |
34 return true; | |
35 case gfx::GpuMemoryBuffer::ATC: | |
36 case gfx::GpuMemoryBuffer::ATCIA: | |
37 case gfx::GpuMemoryBuffer::DXT1: | |
38 case gfx::GpuMemoryBuffer::DXT5: | |
39 case gfx::GpuMemoryBuffer::ETC1: | |
40 case gfx::GpuMemoryBuffer::R_8: | |
41 case gfx::GpuMemoryBuffer::RGBA_8888: | |
42 case gfx::GpuMemoryBuffer::BGRA_8888: | |
43 case gfx::GpuMemoryBuffer::YUV_420: | |
44 return false; | |
45 } | |
46 NOTREACHED(); | |
47 return false; | |
48 case GL_RGBA: | 22 case GL_RGBA: |
49 switch (format) { | 23 case GL_BGRA_EXT: |
50 case gfx::GpuMemoryBuffer::BGRA_8888: | 24 return true; |
51 return true; | |
52 case gfx::GpuMemoryBuffer::ATC: | |
53 case gfx::GpuMemoryBuffer::ATCIA: | |
54 case gfx::GpuMemoryBuffer::DXT1: | |
55 case gfx::GpuMemoryBuffer::DXT5: | |
56 case gfx::GpuMemoryBuffer::ETC1: | |
57 case gfx::GpuMemoryBuffer::R_8: | |
58 case gfx::GpuMemoryBuffer::RGBX_8888: | |
59 case gfx::GpuMemoryBuffer::RGBA_8888: | |
60 case gfx::GpuMemoryBuffer::YUV_420: | |
61 return false; | |
62 } | |
63 NOTREACHED(); | |
64 return false; | |
65 case GL_R8: | |
66 return false; | |
67 default: | 25 default: |
68 return false; | 26 return false; |
69 } | 27 } |
70 } | 28 } |
71 | 29 |
| 30 bool ValidFormat(gfx::GpuMemoryBuffer::Format format) { |
| 31 switch (format) { |
| 32 case gfx::GpuMemoryBuffer::RGBA_8888: |
| 33 case gfx::GpuMemoryBuffer::BGRA_8888: |
| 34 case gfx::GpuMemoryBuffer::RGBX_8888: |
| 35 return true; |
| 36 case gfx::GpuMemoryBuffer::ATC: |
| 37 case gfx::GpuMemoryBuffer::ATCIA: |
| 38 case gfx::GpuMemoryBuffer::DXT1: |
| 39 case gfx::GpuMemoryBuffer::DXT5: |
| 40 case gfx::GpuMemoryBuffer::ETC1: |
| 41 case gfx::GpuMemoryBuffer::R_8: |
| 42 case gfx::GpuMemoryBuffer::YUV_420: |
| 43 return false; |
| 44 } |
| 45 |
| 46 NOTREACHED(); |
| 47 return false; |
| 48 } |
| 49 |
72 EGLint FourCC(gfx::GpuMemoryBuffer::Format format) { | 50 EGLint FourCC(gfx::GpuMemoryBuffer::Format format) { |
73 switch (format) { | 51 switch (format) { |
74 case gfx::GpuMemoryBuffer::BGRA_8888: | 52 case gfx::GpuMemoryBuffer::BGRA_8888: |
75 return DRM_FORMAT_ARGB8888; | 53 return DRM_FORMAT_ARGB8888; |
76 case gfx::GpuMemoryBuffer::RGBX_8888: | 54 case gfx::GpuMemoryBuffer::RGBX_8888: |
77 return DRM_FORMAT_XRGB8888; | 55 return DRM_FORMAT_XRGB8888; |
78 case gfx::GpuMemoryBuffer::ATC: | 56 case gfx::GpuMemoryBuffer::ATC: |
79 case gfx::GpuMemoryBuffer::ATCIA: | 57 case gfx::GpuMemoryBuffer::ATCIA: |
80 case gfx::GpuMemoryBuffer::DXT1: | 58 case gfx::GpuMemoryBuffer::DXT1: |
81 case gfx::GpuMemoryBuffer::DXT5: | 59 case gfx::GpuMemoryBuffer::DXT5: |
(...skipping 19 matching lines...) Expand all Loading... |
101 unsigned internalformat) | 79 unsigned internalformat) |
102 : GLImageEGL(size), internalformat_(internalformat) { | 80 : GLImageEGL(size), internalformat_(internalformat) { |
103 } | 81 } |
104 | 82 |
105 GLImageLinuxDMABuffer::~GLImageLinuxDMABuffer() { | 83 GLImageLinuxDMABuffer::~GLImageLinuxDMABuffer() { |
106 } | 84 } |
107 | 85 |
108 bool GLImageLinuxDMABuffer::Initialize(const base::FileDescriptor& handle, | 86 bool GLImageLinuxDMABuffer::Initialize(const base::FileDescriptor& handle, |
109 gfx::GpuMemoryBuffer::Format format, | 87 gfx::GpuMemoryBuffer::Format format, |
110 int pitch) { | 88 int pitch) { |
111 if (!ValidFormat(internalformat_, format)) { | 89 if (!ValidInternalFormat(internalformat_)) { |
112 LOG(ERROR) << "Invalid format: " << internalformat_; | 90 LOG(ERROR) << "Invalid internalformat: " << internalformat_; |
113 return false; | 91 return false; |
114 } | 92 } |
115 | 93 |
| 94 if (!ValidFormat(format)) { |
| 95 LOG(ERROR) << "Invalid format: " << format; |
| 96 return false; |
| 97 } |
| 98 |
116 if (!IsHandleValid(handle)) { | 99 if (!IsHandleValid(handle)) { |
117 LOG(ERROR) << "Invalid file descriptor: " << handle.fd; | 100 LOG(ERROR) << "Invalid file descriptor: " << handle.fd; |
118 return false; | 101 return false; |
119 } | 102 } |
120 | 103 |
121 // Note: If eglCreateImageKHR is successful for a EGL_LINUX_DMA_BUF_EXT | 104 // Note: If eglCreateImageKHR is successful for a EGL_LINUX_DMA_BUF_EXT |
122 // target, the EGL will take a reference to the dma_buf. | 105 // target, the EGL will take a reference to the dma_buf. |
123 EGLint attrs[] = {EGL_WIDTH, | 106 EGLint attrs[] = {EGL_WIDTH, |
124 size_.width(), | 107 size_.width(), |
125 EGL_HEIGHT, | 108 EGL_HEIGHT, |
126 size_.height(), | 109 size_.height(), |
127 EGL_LINUX_DRM_FOURCC_EXT, | 110 EGL_LINUX_DRM_FOURCC_EXT, |
128 FourCC(format), | 111 FourCC(format), |
129 EGL_DMA_BUF_PLANE0_FD_EXT, | 112 EGL_DMA_BUF_PLANE0_FD_EXT, |
130 handle.fd, | 113 handle.fd, |
131 EGL_DMA_BUF_PLANE0_OFFSET_EXT, | 114 EGL_DMA_BUF_PLANE0_OFFSET_EXT, |
132 0, | 115 0, |
133 EGL_DMA_BUF_PLANE0_PITCH_EXT, | 116 EGL_DMA_BUF_PLANE0_PITCH_EXT, |
134 pitch, | 117 pitch, |
135 EGL_NONE}; | 118 EGL_NONE}; |
136 return GLImageEGL::Initialize( | 119 return GLImageEGL::Initialize(EGL_LINUX_DMA_BUF_EXT, |
137 EGL_LINUX_DMA_BUF_EXT, static_cast<EGLClientBuffer>(NULL), attrs); | 120 static_cast<EGLClientBuffer>(nullptr), attrs); |
138 } | 121 } |
139 | 122 |
140 } // namespace gfx | 123 } // namespace gfx |
OLD | NEW |