Recently ZTE acknowledged the existence of a vulnerability in its Android-based smartphone Score M. The said vulnerability, if exploited, can allow attackers to operate with root privileges-a scenario that can mean an attacker will have complete control over the affected phone. We have taken some time to analyze this backdoor in order to help affected users remove it from their Score M handsets.
This backdoor is an ELF (executable and linkable format) file under /system/bin/ named “sync_agent”. It has a default “setuid” permission which, after it launches, has the ability to set itself as root.
Upon execution, this backdoor checks the password provided against the password indicated in its code, “ztex1609523” and if verified correct, raises a system call [setuid] with ‘0’ as parameter. Note that since the backdoor has a setuid attribute, even if the user who launched the backdoor does not have root privilege, the system call can still execute successfully. Doing so also sets the backdoor’s EUID (effective UID) to 0, which also means a root privilege.
The backdoor then launches the program /system/bin/sh to get a root shell.
data:image/s3,"s3://crabby-images/a461f/a461fb468c1dace3954c741998982ab288ea17bb" alt="figure1-root"
data:image/s3,"s3://crabby-images/329ed/329ed83393c71298eeb7cc845789bc225e40e8af" alt="figure2_systemcalls"
Based on our analysis, it appears this root shell can only be used locally, because this backdoor didn’t open any socket or any other remote communication tunnel.
However, we believe it can be used by other malicious applications to combine a remote root shell. The only thing the malicious app needs to do is provide a bash script to the backdoor, then the said script will be executed.
For instance, if we write a shell script as seen below:
data:image/s3,"s3://crabby-images/bebaf/bebaf2b7acfc0d13f1a71ddab25cc259bf39063c" alt="figure3-sample-script"
Now we run the backdoor that has been provided our script as a parameter.
data:image/s3,"s3://crabby-images/28f44/28f44f26902389fb84adeafc3dd558d8d26a574c" alt="figure4-script-success"
We then use strace to print the system call log. See below:
data:image/s3,"s3://crabby-images/5fb84/5fb8416428b7b44c97fbc8a210cb08cc548cf183" alt="figure5-system-call-log"
In conclusion, a malware can easily use this backdoor in combination with a remote backdoor or bot. The preinstalled backdoor need only receive an SMS command or connect to a remote C&C server to receive commands from a remote attacker, and then call the local backdoor with a certain shell script.
If you own a ZTE Score M you can remove this backdoor by following these instructions:
- Run the backdoor on an adb shell: /system/bin/sync_agent ztex1609523
- To check which device your /system dir has mounted, use the command: mount. There should be a print out like below, note the device name underlined in red:
- Remount the system partition as RW with command: mount -o remount,rw /your/device/name /system.
- Remove the backdoor from the system with command: rm /system/bin/sync_agent.
- Terminate the backdoor with ctrl+c.
To keep your mobile device safe from malicious applications, make sure you have a trusty mobile security solution installed like the Mobile Security Personal Edition.
To know more on how to better protect yourself from threats related to your mobile devices, you may read our comprehensive e-guides below:
Leave a reply