diff options
author | Peiyong Lin <lpy@google.com> | 2023-07-07 16:46:16 +0000 |
---|---|---|
committer | Peiyong Lin <lpy@google.com> | 2023-07-07 17:48:29 +0000 |
commit | 1d6261388df9c5f6866bd4f2b296ad685c79badc (patch) | |
tree | 48f9b0565ff992bd1e071dce629534f1c455bb7b /opengl | |
parent | 3e56f7e70206c19e4846f368bb182d6b58f87d7c (diff) | |
download | native-1d6261388df9c5f6866bd4f2b296ad685c79badc.tar.gz |
Revert "Load native GLES driver when specified."
This reverts commit 0d60e80ad8162e791305dfb8844a59f1ef9840d3.
Reason for revert: culprit of boot memory regression
Original commit message:
"""
Load native GLES driver when specified.
Since ANGLE and native GLES drivers can coexist, when native is
specified, the loader must load the native GLES drivers specified in
ro.hardware.egl. This patch adds the support to load native GLES drivers
when specified.
Bug: b/283858001
Test: atest CtsAngleDeveloperOptionHostTest -c with ANGLE being default
Test: atest CtsAngleDeveloperOptionHostTest -c with native being default
"""
Bug: b/283858001
Bug: b/289956225
Change-Id: I785d2d3ff8dd21a1a207ccd814b5dddb080e9b52
Test: forrest test
Diffstat (limited to 'opengl')
-rw-r--r-- | opengl/libs/EGL/Loader.cpp | 29 |
1 files changed, 6 insertions, 23 deletions
diff --git a/opengl/libs/EGL/Loader.cpp b/opengl/libs/EGL/Loader.cpp index 654e5b7c03..8d0eb590bf 100644 --- a/opengl/libs/EGL/Loader.cpp +++ b/opengl/libs/EGL/Loader.cpp @@ -169,11 +169,6 @@ static bool should_unload_system_driver(egl_connection_t* cnx) { } } - // Return true if native GLES drivers should be used and ANGLE is already loaded. - if (android::GraphicsEnv::getInstance().shouldUseNativeDriver() && cnx->angleLoaded) { - return true; - } - // Return true if updated driver namespace is set. ns = android::GraphicsEnv::getInstance().getDriverNamespace(); if (ns) { @@ -245,28 +240,16 @@ void* Loader::open(egl_connection_t* cnx) { if (!hnd) { // Secondly, try to load from driver apk. hnd = attempt_to_load_updated_driver(cnx); - - // If updated driver apk is set but fail to load, abort here. - LOG_ALWAYS_FATAL_IF(android::GraphicsEnv::getInstance().getDriverNamespace(), - "couldn't find an OpenGL ES implementation from %s", - android::GraphicsEnv::getInstance().getDriverPath().c_str()); } - // Attempt to load native GLES drivers specified by ro.hardware.egl if native is selected. - // If native is selected but fail to load, abort. - if (!hnd && android::GraphicsEnv::getInstance().shouldUseNativeDriver()) { - auto driverSuffix = base::GetProperty(RO_DRIVER_SUFFIX_PROPERTY, ""); - LOG_ALWAYS_FATAL_IF(driverSuffix.empty(), - "Native GLES driver is selected but not specified in %s", - RO_DRIVER_SUFFIX_PROPERTY); - hnd = attempt_to_load_system_driver(cnx, driverSuffix.c_str(), true); - LOG_ALWAYS_FATAL_IF(!hnd, "Native GLES driver is selected but failed to load. %s=%s", - RO_DRIVER_SUFFIX_PROPERTY, driverSuffix.c_str()); - } - - // Finally, try to load default driver. bool failToLoadFromDriverSuffixProperty = false; if (!hnd) { + // If updated driver apk is set but fail to load, abort here. + if (android::GraphicsEnv::getInstance().getDriverNamespace()) { + LOG_ALWAYS_FATAL("couldn't find an OpenGL ES implementation from %s", + android::GraphicsEnv::getInstance().getDriverPath().c_str()); + } + // Finally, try to load system driver. // Start by searching for the library name appended by the system // properties of the GLES userspace driver in both locations. // i.e.: |