out-of-tree kernel {module, exploit} development tool
Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.
 
 
 
dump_stack() 5116ffe015 Implements bootstrap, fixes #3 pirms 3 gadiem
config Implements kernels config autogeneration pirms 3 gadiem
examples Print kernel config skeleton to stdout pirms 3 gadiem
qemu Add ssh command generator pirms 3 gadiem
tools Remove CentOS and Debian from kernel factory pirms 3 gadiem
.gitignore Initial commit pirms 3 gadiem
LICENSE Change license to GNU AGPLv3 pirms 3 gadiem
README.md Update README.md pirms 3 gadiem
bootstrap.config.go Implements bootstrap, fixes #3 pirms 3 gadiem
bootstrap.go Implements bootstrap, fixes #3 pirms 3 gadiem
debug.go Move gdb listen address to params pirms 3 gadiem
gen.go Implements skeleton module/exploit config generator pirms 3 gadiem
kernel.go Allow to force bump docker container pirms 3 gadiem
main.go Implements bootstrap, fixes #3 pirms 3 gadiem
pew.go Improve error logging pirms 3 gadiem

README.md

out-of-tree

out-of-tree kernel {module, exploit} development tool

Screenshot

Installation

$ go get github.com/jollheef/out-of-tree
$ out-of-tree bootstrap

Then you can check it on kernel module example:

$ cd $GOPATH/github.com/jollheef/out-of-tree/examples/kernel-module
$ out-of-tree kernel autogen # generate kernels based on .out-of-tree.toml
$ out-of-tree pew

Examples

Run by absolute path

$ out-of-tree --path /path/to/exploit/directory pew

Test only with one kernel:

$ out-of-tree pew --kernel='Ubuntu:4.10.0-30-generic'

Run debug environment:

$ out-of-tree debug --kernel='Ubuntu:4.10.0-30-generic'

Test binary module/exploit with implicit defined test ($BINARY_test)

$ out-of-tree pew --binary /path/to/exploit

Test binary module/exploit with explicit defined test

$ out-of-tree pew --binary /path/to/exploit --test /path/to/exploit_test

Guess work kernels:

$ out-of-tree pew --guess

Use custom kernels config

$ out-of-tree --kernels /path/to/kernels.toml pew

Generate all kernels

Does not required if you dont need to use --guess.

$ cd $GOPATH/src/github.com/jollheef/out-of-tree/tools/kernel-factory
$ ./bootstrap.sh # more than 6-8 hours for all kernels
$ export OUT_OF_TREE_KCFG=$GOPATH/src/github.com/jollheef/out-of-tree/tools/kernel-factory/output/kernels.toml

Development

Read Qemu API.

Generate images

$ cd $GOPATH/src/github.com/jollheef/out-of-tree/tools/qemu-debian-img/
$ docker run --privileged -v $(pwd):/shared -e IMAGE=/shared/ubuntu1404.img -e RELEASE=trusty -t gen-ubuntu1804-image
$ docker run --privileged -v $(pwd):/shared -e IMAGE=/shared/ubuntu1604.img -e RELEASE=xenial -t gen-ubuntu1804-image