DUO-DE is a GSI variant Android ROM created for Microsoft Surface Duo devices, offering a clean AOSP experience. This build combines gapps/vanila variants of the GSI ROM from ponces with desktop mode enabled + various tweaks to make it nice and smooth with the help of thain tweaks. All credits go to respective developers.
Before you proceed, please take a moment to read this announcement regarding this project. By using this ROM, you are agreeing to the DISCLAIMER
.
With the posture processor engine, both duo1 and duo2 react to various postures. Specifically, the touch configurations and display settings will toggle between left-screen phone mode, right-screen phone mode, and tablet mode based on the hinge position. The hinge gaps can be enabled/disabled through the treble app.
This ROM switches between tablet mode (first image) and phone mode (second image) when you change the postures. These modes are optimized (both visually and utility-wise) for each of the situations and the screen's real state.
Tip
In case your device does not react to tent or ramp mode (landscaped phone mode) by default, you have to enable it from the Home settings
. When you are in Phone mode, click and hold on the desktop, click Home settings
on the popup menu, and enable the Allow home screen rotation
feature. This will enable the launcher to serve the Tent mode and Ramp modes.
Floating windowed mode can be enabled/disabled for tablet mode and phone mode separately. To do that, click and hold the desktop, click Home settings
, and find the settings Tablet Mode Floating Windows
and Phone Mode Floating Windows
.
You can still launch apps in split window mode (similar to the Stock 12L) using two methods,
- Click and hold the application icon, and click the option
Split Screen
from the popup menu - Launch the apps first, and use the gesture (or recent apps button on the navigation bar) to access the recent apps window and click
Split
.
Both options will prompt you to open the second application to share the screen.
While DUO-DE works smoothly on both Surface Duo (Gen1) and Surface Duo 2, some of the extra functionalities of Duo2 (like ultrawide or zoom sensors of cameras, surface pen charging) require a lot of reverse engineering work. The Duo2 reverse engineering work is led by Ethanol10. Currently, we have extracted lot of information about Duo2, however realizing them as features would take time due to the amount of development and testing required. Discussions related to reverse engineering Duo2 are available here.
These results are just for reference (for people who enjoy numbers) to compare the CPU and GPU performance of this ROM (latest build) with other operating system options. The best-case numbers of each operating system are included in the graphs.
Comparison | duo-de Results |
---|---|
duo-de cpu | |
duo-de gpu |
All DUO-DE releases are signed with release keys, ensuring protection against malicious OTA updates and unauthorized system application replacements. Additionally, DUO-DE passes play integrity checks, safeguarding against malicious applications. For more details about the security of GSI images like DUO-DE, visit this post.
Warning
Try this at your own risk and proceed with caution!
Tip
Please read the release notes before performing OTA updates, Some major updates may require you to wipe user data. I highly recommend you backup your application data!
Caution
BACKUP your user data before proceeding, it might prompt you to wipe the user data partition depending on your current setup.
Following are the steps to flash this image to your surface duo.
- Download the release.
wget https://github.com/Archfx/duo-de/releases/download/[[version]]/aosp-arm64-ab-gapps-15.0-[[version]].img.xz
- Extract the compressed
*.xz
file to obtain the*.img
. (Windows users can use something like 7-zip, Linux and Mac users can use either of the following commands with respective commandline utilities).
tar -xf aosp-arm64-ab-gapps-15.0-[[version]].img.xz #tar utility
gunzip aosp-arm64-ab-gapps-15.0-[[version]].img.xz #gunzip utility
- If you are migrating from Android 12L (stock) follow this step. You need to unlock the bootloader before proceeding. Please pay attention to commands, do not copy and execute the commands blindly.
adb reboot fastboot
fastboot delete-logical-partition system_ext
fastboot delete-logical-partition product
#get the current slot
fastboot getvar current-slot
# if current slot is a, delete the system_b
fastboot delete-logical-partition system_b
# if current slot is b, delete the system_a
fastboot delete-logical-partition system_a
fastboot flash system aosp-arm64-ab-gapps-15.0-[[version]].img
fastboot reboot
# upon reboot, it will prompt to wipe the user data partition.
- Migrating from 13/14 pixel experience, follow the below steps
adb reboot fastboot
fastboot flash system aosp-arm64-ab-gapps-15.0-[[version]].img
fastboot reboot
- Enable the following settings from the developer options and perform a manual reboot.
- Force activities to be resizable
- Enable freeform windows
- Enable non-resizable in multi-window
- Once you flash a duo-de version using the above steps, subsequent updates will be received using OTA. You can check updates using
settings -> system -> system updates
.If prompted to select the default updater, select
PHH treble updater
for always. - Enable the ideal
Treble Settings
as outlined here. - If you wish to see future updates and feature improvements, consider starring (★) the project—it motivates the development of new releases!
Any issues, please open an issue with a detailed description. Please use the discussion section for any questions regarding flashing and similar stuff.
These people have helped this project in some way or another, so they should be the ones who receive all the credit:
phhusson AndyYan eremitein kdrag0n Peter Cai haridhayal11 sooti Iceows ChonDoit ponces thai-ng farmerbb Ethanol10
THIS REPOSITORY CONTAINS A CUSTOM ANDROID GENERIC SYSTEM IMAGE (GSI) ROM PROVIDED "AS IS," WITHOUT WARRANTY OF ANY KIND. USE, DOWNLOAD, OR INSTALLATION OF THIS SOFTWARE IS AT YOUR OWN RISK. THE AUTHORS ARE NOT LIABLE FOR ANY DAMAGES, INCLUDING BUT NOT LIMITED TO DEVICE DAMAGE, DATA LOSS, OR OTHER ISSUES RESULTING FROM THE USE OR INSTALLATION OF THIS ROM. INSTALLING CUSTOM ROMS MAY VOID YOUR DEVICE'S WARRANTY AND COULD BRICK YOUR DEVICE, RENDERING IT UNUSABLE. VERIFY COMPATIBILITY WITH YOUR DEVICE BEFORE INSTALLATION. NO GUARANTEE OF UPDATES, FIXES, OR SUPPORT IS PROVIDED. THIRD-PARTY SOFTWARE INCLUDED IS SUBJECT TO ITS OWN TERMS. MODIFICATION AND REDISTRIBUTION ARE PERMITTED UNDER THE PROVIDED LICENSE, BUT AUTHORS DISCLAIM LIABILITY FOR ISSUES ARISING FROM SUCH ACTIONS. BY PROCEEDING, YOU ACCEPT THESE TERMS. IF YOU DO NOT AGREE, DO NOT USE THIS FIRMWARE IMAGE.