Sony Xperia XA2
Manufacturer

Sony

Name

Xperia XA2

Identifier

sony-pioneer

System Type

android

SoC

qualcomm-sdm660

Architecture

aarch64-linux

Supports Stage-0

no

Source

Mobile NixOS repository

Builds

Hydra (default build)

Building

This will build the default output for your Sony Xperia XA2.

$ nix-build --argstr device sony-pioneer -A build.default

Installation

The device will need to be booted in its bootloader, or fastboot, mode. The boot image can be installed using the following command, assuming it was built using the previous command.

$ result/flash-critical.sh

If you have a system image (system.img) built, you can use fastboot to flash it to the device. Note that it might be too big to fit over the system partition. In such case, it can be flashed on the userdata partition.

Warning
This will erase everything on the partition. Additionally, the common backups methods, e.g. TWRP, will not backup the userdata partition.
$ fastboot flash userdata system.img

Device-specific notes

Fastboot

This device has a quirky way to get to fastboot.

  • You have to have the device connected to a computer, or else it will not activate fastboot mode.

  • Fastboot shows nothing on the display

With the phone connected to a computer, hold volume up and somehow cause a reboot (from the system, or by holding power to force reset).

Alternatively, from a powered-off state, hold volume up and connect to your computer.

Finally, you can always trigger a reboot to bootloader via software. From within Mobile NixOS, sudo reboot bootloader, or from an Android-based system using adb reboot bootloader or equivalent methods.

Note that the LED will light up blue when in fastboot mode.

Failure to fastboot flash

It is possible that you might run into issues with this device when connected to a USB3 port with a USB3 cable. If that happens:

  1. Check if there is a USB2 port on your computer or on the USB hub you are using. Connect your phone to the USB2 port for flashing instead.

  2. If your USB hub only has USB3 ports, then connect the hub to PC with a USB2 data cable, and XA2 to the hub with any USB data cable ("USB Type-C" in the XA2 end).

  3. If there are only USB3 ports available, you can force your USB3 ports to USB2 mode.

Forcing USB3 ports to USB2 mode

The following commands will force all USB3 ports to USB2 mode temporarily.

 $ nix-shell -p pciutils
 [nix-shell:~]$ lspci -nn | grep USB | cut -d '[' -f3 | cut -d ']' -f1 | xargs -I@ sudo setpci -H1 -d @ d0.l=0

After which hopefully the procedure works. After successfully flashing, restart your computer to bring the USB3 ports to their normal mode.

Alternatively, the following commands can be used to revert the change.

 $ nix-shell -p pciutils
 [nix-shell:~]$ lspci -nn | grep USB | cut -d '[' -f3 | cut -d ']' -f1 | xargs -I@ sudo setpci -H1 -d @ d0.l=1

See also: