You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ut_SG560D/UM.9.14/external/minijail
quectel 55794fdde8 QCM6490:Alyssa:upload QCM6490 android12 base code.
Change-Id: If3e3c4e01b19443714d880ae669aaa8b39edfff7
4 years ago
..
examples QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
linux-x86 QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
test QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
tools QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
.clang-format QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
Android.bp QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
CPPLINT.cfg QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
Cargo.toml QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
CleanSpec.mk QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
HACKING.md QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
LICENSE QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
MODULE_LICENSE_BSD QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
Makefile QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
NOTICE QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
OWNERS QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
OWNERS.rust QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
PRESUBMIT.cfg QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
PREUPLOAD.cfg QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
README.md QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
RELEASE.md QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
TEST_MAPPING QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
arch.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
bpf.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
bpf.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
build.rs QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
common.mk QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
dump_constants.cc QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
elfparse.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
elfparse.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
gen_constants-inl.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
gen_constants.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
gen_constants.sh QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
gen_syscalls.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
gen_syscalls.sh QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
get_googletest.sh QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
lib.rs QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libconstants.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libminijail-private.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libminijail.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libminijail.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libminijail.pc.in QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libminijail.rs QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libminijail_unittest.cc QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libminijailpreload.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
libsyscalls.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
minijail0.1 QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
minijail0.5 QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
minijail0.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
minijail0_cli.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
minijail0_cli.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
minijail0_cli_unittest.cc QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
navbar.md QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
parse_seccomp_policy.cc QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
platform2_preinstall.sh QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
scoped_minijail.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
setup.py QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
signal_handler.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
signal_handler.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
syscall_filter.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
syscall_filter.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
syscall_filter_unittest.cc QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
syscall_filter_unittest_macros.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
syscall_wrapper.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
syscall_wrapper.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
system.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
system.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
system_unittest.cc QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
testrunner.cc QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
util.c QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
util.h QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago
util_unittest.cc QCM6490:Alyssa:upload QCM6490 android12 base code. 4 years ago

README.md

Minijail

The Minijail homepage and main repo is https://android.googlesource.com/platform/external/minijail/.

There might be other copies floating around, but this is the official one!

[TOC]

What is it?

Minijail is a sandboxing and containment tool used in Chrome OS and Android. It provides an executable that can be used to launch and sandbox other programs, and a library that can be used by code to sandbox itself.

Getting the code

You're one git clone away from happiness.

$ git clone https://android.googlesource.com/platform/external/minijail
$ cd minijail

Releases are tagged as linux-vXX: https://android.googlesource.com/platform/external/minijail/+refs

Building

See the HACKING.md document for more details.

Release process

See the RELEASE.md document for more details.

Additional tools

See the tools/README.md document for more details.

Contact

We've got a couple of contact points.

Talks and presentations

The following talk serves as a good introduction to Minijail and how it can be used.

Video, slides.

Example usage

The Chromium OS project has a comprehensive sandboxing document that is largely based on Minijail.

After you play with the simple examples below, you should check that out.

Change root to any user

# id
uid=0(root) gid=0(root) groups=0(root),128(pkcs11)
# minijail0 -u jorgelo -g 5000 /usr/bin/id
uid=72178(jorgelo) gid=5000(eng) groups=5000(eng)

Drop root while keeping some capabilities

# minijail0 -u jorgelo -c 3000 -- /bin/cat /proc/self/status
Name: cat
...
CapInh: 0000000000003000
CapPrm: 0000000000003000
CapEff: 0000000000003000
CapBnd: 0000000000003000