Here I describe the generic way to gain root access on an Android device. This description applies to any Android device using a bootloader that is possible to unlock. Most vendors today ship their bootloaders locked with the option to unlocking them, most often voiding the warranty.
This is the manual way gaining root access. Note that "rooting the phone" often implies installing utilities such as su, the SuperUser app etc. You may do this after using this tutorial, but I'm here only describing the process of getting the initial root access itself.
If you got a well known and/or not brand new device, there probably already exists ready-made one-click tools rooting your device much easier than this. This tutorial is if you don't got such a tool, or for some reason don't want to use them - or if you simply are curious about the methods used.
All tools used here assumes you are using a GNU/Linux environment such as Debian, Ubuntu or so.

Steps

  • Unlock the bootloader
  • Obtain your boot image
  • Unpack the boot image
  • Unpack initramfs root file system
  • Enable insecure mode
  • Pack initramfs
  • Pack boot image
  • Fastboot device using own boot image
  • adb shell to the device

Unlock the Boot-loader

This tutorial assumes you have a device with either an unlocked or unlockable bootloader. This is the most common today. The phone is shipped with the bootloader locked (i.e. tamper proof), but the manufacturer gives you the option to unlock it. This is usually at the cost of the the Digital Rights Manager data (DRM) and also often limits the warranty. This is quite understandable, since you can easily damage the unlocked device for example by overclocking it beyond its thermal capacity, melting the CPU, to mention a worst case scenario.
With the bootloader unlocked, you are able to both boot the device, and/or flash the internal disk, using custom root file system images.
Make sure your vendor allows you to unlock your device before continuing this tutorial. You may wait with the actual unlocking until you created your new boot image, though. If you can't find any information about the state of your bootloader, just try booting you device with the image you'll build here. Either it works, or your device politely refuses it.

Obtaining the boot image

Now you'll need to get hold your original boot image. You can either extract this from the device itself, get it from your manufacturer or from some trusted source on the Internet providing original images. Often the original distribution is a zip archive (but not necessary with the .zip extension). Unzip it to get the boot.img file.

Unpacking the boot image

The boot image (boot.img) is composed of both the kernel and the initial root file system (initramfs). To split this, you'll need some utility. I've written such tool here below. There are several other, often script based, tools out there as well.

Unpacking the root file system

Now you need to unpack the root file system. It's a gziped cpio archive, and can be unpacked using standard GNU/Linux utilities. To preserve file ownership, perform this either as the root user, or run fakeroot.
# mkdir rootfs
# cd rootfs
# gzip -cd ../initramfs.cpio.gz | cpio -i
Now the file system is unpacked in the directory "rootfs".

Set the Android to insecure

Android got a security feature you can turn on or off. Usually this should be enabled for production environment and disabled for development devices. By turning security off, you can gain root access.
  • Edit /default.prop in the root file system and set the property "ro.secure=0".

Pack the root file system

All done, now we only have to repack everything again. Pack the root file system.
# cd rootfs
# find . | cpio -o -H newc | gzip > ../insecure_ramdisk.cpio.gz
# cd ..

Compile the boot image

Now we build the new insecure boot image. Use the same parameters unmkbootimg suggested to get base address and so correct. If unmkbootimg didn't print out any base address, it's because default is used, and you won't need to specify it to mkbootimg neither.
$ mkbootimg --kernel kernel.gz --ramdisk insecure_initramfs.cpio.gz --base 0x20000000
            --cmdline 'no_console_suspend=1' -o insecure_boot.img
Please note that the kernel file may be called "kernel.gz", "zImage" or similar depending on what tools used extracting it from the original boot image.

Boot the device in Insecure mode

Now you've got a new boot image with security disabled. Boot, but avoid flashing if possible, the device using this image. To be able to do this, the device must be put in fastboot mode. This is usually one of the following.
  • Device powered off. Press and hold Volume-UP during power on.
  • Device powered off. Press and hold Volume-UP and insert USB cable connected to computer.
If this doesn't work, Google "fastboot" plus your device name.
Once in fastboot, boot the phone using the fastboot command, supplied with the Android SDK.
$ fastboot boot insecure_boot.img
Now the phone will (hopefully) start and look as usual. The only difference is that security is turned off.

Open a root shell on you device

Now connecting to you device using ADB (also part of Android SDK), you'll get a root shell, instead of running as the "shell" user. This is thanks to disabled security.
$ adb shell
root@android:/ #
You are now root! Do whatever you want, e.g. installing a su program in /system/bin etc. Remember to remount /system in read/write mode before you can write anything there.
Because you did not flash your device with the insecure boot image, the next time you reboot it, security will be turned on again, for your protection. The modifications you've done on /system are of course still there.
Since the root file system is restored from the boot image each boot, no changes done here will survive a reboot. Still, you can follow this tutorial making permanent changes at the root disk, flashing the boot image instead of only booting it.
$ fastboot flash boot my_boot.img
I don't recommend using ro.secure=0 as default, though, but there may be other changes you want to apply to the root disk.

It didn't work?!

Everything in this guide went well, but still, once "adb shell", you still didn't got root, but are stuck at the shell user with the $-prompt?
Some devices seems not to honor the ro.secure property - but despair not, we still can fix this. We just have to install a root shell in the root file system instead. Back at your computer, cd to your rootfs directory from above and make sure your device is connected via the USB cable and up and running. Then issue the commands below to perform this.
root@ubuntu:~/rootfs# adb pull /system/bin/sh sbin/rootsh
root@ubuntu:~/rootfs# chmod a+x sbin
root@ubuntu:~/rootfs# chown root sbin/rootsh 
root@ubuntu:~/rootfs# chgrp 2000 sbin/rootsh 
root@ubuntu:~/rootfs# chmod 4750 sbin/rootsh 
Now go back and continue from "Pack the root file system" above to create a new boot image. Once the device is booted using this new image you can execute your root shell to gain root.
root@ubuntu:~# adb shell
shell@android:/$ /sbin/rootsh +p
# 
You are now root.
If you'd like to continue installing the Superuser App, you can look at this post at XDA forum.

Feedback? Questions? Suggestions?

This tutorial too basic? Too complicated? Inaccuracies? Did not work as expected?
Please feel free send me a mail!

Post a Comment

 
Top