blob: 18be27ac0e5b35cf79c2cc425d9f6ed847c3b27b [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ui/gl/gl_egl_api_implementation.h"
#include "base/command_line.h"
#include "base/strings/string_split.h"
#include "base/strings/string_util.h"
#include "ui/gl/gl_context.h"
#include "ui/gl/gl_implementation.h"
#include "ui/gl/gl_surface_egl.h"
namespace gl {
RealEGLApi* g_real_egl = nullptr;
DebugEGLApi* g_debug_egl = nullptr;
void InitializeStaticGLBindingsEGL() {
g_driver_egl.InitializeStaticBindings();
if (!g_real_egl) {
g_real_egl = new RealEGLApi();
}
g_real_egl->Initialize(&g_driver_egl);
g_current_egl_context = g_real_egl;
}
void InitializeDebugGLBindingsEGL() {
if (!g_debug_egl) {
g_debug_egl = new DebugEGLApi(g_real_egl);
}
g_current_egl_context = g_debug_egl;
}
void ClearBindingsEGL() {
if (g_debug_egl) {
delete g_debug_egl;
g_debug_egl = NULL;
}
if (g_real_egl) {
delete g_real_egl;
g_real_egl = NULL;
}
g_current_egl_context = nullptr;
g_driver_egl.ClearBindings();
}
EGLApi::EGLApi() {
}
EGLApi::~EGLApi() {
}
EGLApiBase::EGLApiBase()
: driver_(NULL) {
}
EGLApiBase::~EGLApiBase() {
}
void EGLApiBase::InitializeBase(DriverEGL* driver) {
driver_ = driver;
}
RealEGLApi::RealEGLApi() {
}
RealEGLApi::~RealEGLApi() {
}
void RealEGLApi::Initialize(DriverEGL* driver) {
InitializeBase(driver);
}
void RealEGLApi::SetDisabledExtensions(const std::string& disabled_extensions) {
DCHECK(GLContext::TotalGLContexts() == 0);
disabled_exts_.clear();
filtered_exts_.clear();
if (!disabled_extensions.empty()) {
std::vector<std::string> candidates =
base::SplitString(disabled_extensions, ", ;", base::KEEP_WHITESPACE,
base::SPLIT_WANT_NONEMPTY);
for (const auto& ext : candidates) {
if (!base::StartsWith(ext, "EGL_", base::CompareCase::SENSITIVE))
continue;
// For the moment, only the following two extensions can be disabled.
// See DriverEGL::UpdateConditionalExtensionBindings().
DCHECK(ext == "EGL_KHR_fence_sync" || ext == "EGL_KHR_wait_sync");
disabled_exts_.push_back(ext);
}
}
}
const char* RealEGLApi::eglQueryStringFn(EGLDisplay dpy, EGLint name) {
if (name == EGL_EXTENSIONS) {
auto it = filtered_exts_.find(dpy);
if (it == filtered_exts_.end()) {
it = filtered_exts_.insert(std::make_pair(
dpy, FilterGLExtensionList(EGLApiBase::eglQueryStringFn(dpy, name),
disabled_exts_))).first;
}
return (*it).second.c_str();
}
return EGLApiBase::eglQueryStringFn(dpy, name);
}
DebugEGLApi::DebugEGLApi(EGLApi* egl_api) : egl_api_(egl_api) {}
DebugEGLApi::~DebugEGLApi() {}
void DebugEGLApi::SetDisabledExtensions(
const std::string& disabled_extensions) {
if (egl_api_) {
egl_api_->SetDisabledExtensions(disabled_extensions);
}
}
TraceEGLApi::~TraceEGLApi() {
}
void TraceEGLApi::SetDisabledExtensions(
const std::string& disabled_extensions) {
if (egl_api_) {
egl_api_->SetDisabledExtensions(disabled_extensions);
}
}
bool GetGLWindowSystemBindingInfoEGL(GLWindowSystemBindingInfo* info) {
EGLDisplay display = eglGetCurrentDisplay();
const char* vendor = eglQueryString(display, EGL_VENDOR);
const char* version = eglQueryString(display, EGL_VERSION);
const char* extensions = eglQueryString(display, EGL_EXTENSIONS);
*info = GLWindowSystemBindingInfo();
if (vendor)
info->vendor = vendor;
if (version)
info->version = version;
if (extensions)
info->extensions = extensions;
return true;
}
void SetDisabledExtensionsEGL(const std::string& disabled_extensions) {
DCHECK(g_current_egl_context);
DCHECK(GLContext::TotalGLContexts() == 0);
g_current_egl_context->SetDisabledExtensions(disabled_extensions);
}
bool InitializeExtensionSettingsOneOffEGL() {
return GLSurfaceEGL::InitializeExtensionSettingsOneOff();
}
} // namespace gl