PRoot

Package: proot

Description: Emulate chroot, bind mount and binfmt_misc for non-root users

Homepages: https://proot-me.github.io

https://github.com/proot-me/PRoot

PRoot is a user-space implementation of,  , and. This means that users don't need any privileges or setup to do things like using an arbitrary directory as the new root filesystem.

The benefits of enabling PRoot include running Linux operating systems in a Termux chroot on an Android smartphone and tablet, and Chromebook. Termux offers Linux operating system software for your device in the following flavors:


 * 1) Arch
 * 2) Archstrike
 * 3) Blackarch
 * 4) Debian
 * 5) Fedora
 * 6) Slackware
 * 7) Ubuntu
 * 8) Alpine Linux

This list of operating systems that run in Termux is not all inclusive. Please add Linux distributions to this list if you have tested them. Also, if you can add or improve any of the installation scripts, the community will be very grateful.

= General Overview of PRoot = PRoot uses `ptrace` system call to fake root privileges. That means it traces each of its child processes to interpret and convert system calls made by the child processes.

PRoot command can be used to execute one command from fake chroot or start a shell session. The latter will be useful for virtualizing guest root file systems of other operating systems.

If you know some command line, run  for a complete help screen. You are advised to learn Linux Command line basics anyway before using any guest OA rootfs.

Also, PRoot only virtualizes the root filesystem tree and not an entire OS. Don't expect things like inserting a kernel module to work.

A performance penalty is observed when you virtualize a rootfs using proot, which is not of course as slowness as using emulators. However, when required packages are available in termux ecosystem, use them because it is easier and faster.

Do not expect everything to work though. Some blogs may mislead people as if they can hack (crack) computers in Termux, or using other tools such as Kali Linux. However, without knowing system internals and programming, it is hardly possible to crack into systems. At worst it may be legally dangerous. Don't expect to do penetration testing in termux unless you are a penetration tester.

= Settings = To be used if  and   are installed: unset LD_PRELOAD export LD_PRELOAD=$PREFIX/lib/libtermux-exec.so

How to unset ?

if you are going to launch or execute startup script containing proot command so before that you will have to unset LD_PRELOAD first (if you have installed termux-exec at same time) otherwise you will get error. Its very easy to unset LD_PRELOAD by executing

How to set back ?

Now if you completed your proot work and you want to use your termux so now you have two options to again set/export LD_PRELOAD :-

1) Just open new session and exit from previous session so now your LD_PRELOAD will be set automatically with new session.

2) If you don't want to open new session because of any reason so you can also export or set LD_PRELOAD path in same session by executing this export LD_PRELOAD=$PREFIX/lib/libtermux-exec.so