Index: ui/gl/gl_image_ozone_native_pixmap.cc |
diff --git a/ui/gl/gl_image_ozone_native_pixmap.cc b/ui/gl/gl_image_ozone_native_pixmap.cc |
index ed721b9b265a9c304b3493789442f81e279132db..46100983f3e1565b29670766064f1ae746284ded 100644 |
--- a/ui/gl/gl_image_ozone_native_pixmap.cc |
+++ b/ui/gl/gl_image_ozone_native_pixmap.cc |
@@ -129,12 +129,17 @@ bool GLImageOzoneNativePixmap::Initialize(ui::NativePixmap* pixmap, |
for (size_t plane = 0; |
plane < gfx::NumberOfPlanesForBufferFormat(pixmap->GetBufferFormat()); |
++plane) { |
+ uint64_t modifier = pixmap->GetDmaBufModifier(plane); |
attrs.push_back(EGL_DMA_BUF_PLANE0_FD_EXT + plane * 3); |
attrs.push_back(pixmap->GetDmaBufFd(plane)); |
attrs.push_back(EGL_DMA_BUF_PLANE0_OFFSET_EXT + plane * 3); |
attrs.push_back(0); |
attrs.push_back(EGL_DMA_BUF_PLANE0_PITCH_EXT + plane * 3); |
attrs.push_back(pixmap->GetDmaBufPitch(plane)); |
+ attrs.push_back(EGL_LINUX_DRM_PLANE0_MODIFIER0_EXT + plane * 3); |
+ attrs.push_back(modifier & 0xffffffff); |
+ attrs.push_back(EGL_LINUX_DRM_PLANE0_MODIFIER1_EXT + plane * 3); |
+ attrs.push_back(static_cast<uint32_t>((modifier >> 32) & 0xffffffff)); |
} |
attrs.push_back(EGL_NONE); |