This change adds a new developer option switch called "Enable ANGLE". It defaults to off. User can choose to toggle it on and off, and the value of the system property "persist.graphics.egl" is changed accordingly: switch off: persist.graphics.egl="" switch on: persist.graphics.egl="angle" When user toggles the switch, a reboot window is popped up asking user to reboot now to make the change takes effect. If user chooses to cancel the reboot, the switch is toggled back. This enforces that a reboot is required whenever the "persis.graphics.egl" value changes. Upon reboot, we will load either ANGLE or native GLES driver as the system driver, based on the value of "persist.graphics.egl". The switch is disabled if ANGLE is not installed in /vendor partition. We use the system property "ro.gfx.angle.supported" as an indicator. We set the two conditions together in angle.mk file. Any device mk file that inherits angle.mk file will result in ANGLE libs installed in /vendor and "ro.gfx.angle.supported" set to true. Bug: b/270994705 Test: m; flash and check Pixel 7 boots fine atest SettingsRoboTests:GraphicsDriverEnableAngleAsSystemDriverControllerTest Change-Id: I565eff614472bb6ba50742e7dfa49b50dca2809f
42 lines
1.3 KiB
Java
42 lines
1.3 KiB
Java
/*
|
|
* Copyright (C) 2022 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package com.android.settings.development;
|
|
|
|
import android.content.Context;
|
|
import android.content.Intent;
|
|
|
|
/**
|
|
* Host of {@link RebootConfirmationDialogFragment} that provides callback when user
|
|
* interacts with the UI.
|
|
*/
|
|
public interface RebootConfirmationDialogHost {
|
|
/**
|
|
* Called when user made a decision to reboot the device.
|
|
*/
|
|
default void onRebootConfirmed(Context context) {
|
|
// user presses button "Reboot now", reboot the device
|
|
final Intent intent = new Intent(Intent.ACTION_REBOOT);
|
|
context.startActivity(intent);
|
|
}
|
|
|
|
/**
|
|
* Called when user made a decision to cancel the reboot
|
|
* Default to do nothing
|
|
*/
|
|
default void onRebootCancelled() {}
|
|
}
|