Skip to content

Latest commit

 

History

History
187 lines (122 loc) · 12.1 KB

README.md

File metadata and controls

187 lines (122 loc) · 12.1 KB

PET

our paper: PET: Prevent Discovered Errors from Being Triggered in the Linux Kernel

abstract

This artifact is applying for an Artifacts Available badge, an Artifacts Functional badge, and an Results Reproduced badge. It provides two main artifact sets for evaluators to reproduce PET. The first artifact set, detailed in Github, enables constructing PET from scratch, and the second artifact set includes kernel images and a root filesystem which allow the evaluator to reproduce our results in an isolated environment without any destructive steps.

Both artifact sets include Proof of Concept (PoC) programs and exploits of vulnerabilities used as test cases and eBPF programs that enable PET protection. After installing the eBPF program, the evaluator can execute the PoC programs and exploits to access the effectiveness of PET, by observing that the error triggering is prevented.

Besides we include user guidance in the first artifact set to help readers understand the design of PET, and develop their own eBPF programs for more error types that have not been covered in PET so far.

In conclusion, the evaluation includes 2 part

  • functional: execute 5 types of vulnerabilities under the protection of BPF programs in the virtual machine, all the errors will be prevented and the system keep functioning.
  • reproducible: 1) reproduce the performance overhead(about 14 hours), 2) adding new BPF programs from scratch.

set up

Evaluators needs to git clone https://github.com/purplewall1206/PET, and download the qemu root filesystem and compiled kernel images from https://tinyurl.com/2428uac5 in the <path-to-PET>/1-evaluation/.

then evaluators needs to ensure qemu, open-ssh has been installed.

after that, evaluators can execute evaluate.sh, then the virtual machine will be started and 2 terminals will be pop up, there will be three directories, including bpf, PoCs, scripts.

result

functional evaluation

boot up BPF programs by executing start-bpf-progs.sh in terminal 2.

and execute proof-of-concepts in terminal 1.

  • (E1): Test if the BPF program can prevent an integer overflow vulnerability CVE-2017-7184 from being triggered.
    • Execution: execute test-CVE-2017-7184.sh in terminal 1
    • Results: There will be killed signal in terminal 1, and there will be a report ====CVE-2017-7184 is happened==== in terminal 2.
  • (E2): Test if the BPF program can prevent an out-of-bound vulnerability CVE-2016-6187 from being triggered.
    • Execution: execute test-CVE-2016-6187.sh in terminal 1
    • Results: There will be killed signal in terminal 1, and there will be a report ====CVE-2016-6187 is happened==== in terminal 2.
  • (E3): Test if the BPF program can prevent an use-after-free vulnerability CVE-2021-4154 from being triggered.
    • Execution: execute test-CVE-2021-4154.sh in terminal 1
    • Results: Because of the quarantine & sweep policy, the dangling pointer of a use-after-free vulnerability will be quarantined, the vulnerability will not be triggered. Proof-of-concept in terminal 1 cannot trigger the vulner- ability, and terminal 2 will report dangling pointers are quarantined.
  • (E4): Test if the BPF program can prevent an uninitialization vulnerability kmsan-4b28366af7d9 from being triggered.
    • Execution: execute test-kmsan_4b28366af7d9.sh in terminal 1
    • Results: The vulnerability is triggered in terminal1 under an conservative check policy, it means that the BPF program will catch the uninitialization memory but not kill the process. There will be reports ====kmsan-4b28366af7d9 is happened==== in terminal 2.
  • (E5): Test if the BPF program can prevent a data race vulnerability kcsan-dcf8e5633e2e from being triggered.
    • Execution: KCSAN does not provide proof-of-concept,so no proof-of-concept is executed in terminal 1.
    • Results: The BPF program detector_kcsan_dcf8e5633e2ewill be keep checking if the vulnerability kcsan-dcf8e5633e2e is being triggered.

The demo presentation can be seen in YouTube

YouTube demo presentation

reproducible evaluation

performance overhead

after the functional evaluation, shut down the environment, and run evaluate.sh again to reset the environment for performance overhead test.

execute /root/scripts/phoro-run.sh, 7 performance tests with phoronix-test-suites will be executed, 7 seperate performance tests are queued to be executed, including the vanilla, system protected by 5 BPF program individually and simultaneously.

execute phoronix-test-suites result-file-to-text evaluation-*, the results will be outputed.

attention: it will takes at least 2 hours for one test, and 14 hours in total

parse the data

  • extract all the data in to csv format
phoronix-test-suite result-file-to-csv evaluation-vanilla
phoronix-test-suite result-file-to-csv evaluation-CVE-2017-7184
phoronix-test-suite result-file-to-csv evaluation-CVE-2016-6187
phoronix-test-suite result-file-to-csv evaluation-CVE-2021-4154
phoronix-test-suite result-file-to-csv evaluation-kmsan_4b28366af7d9
phoronix-test-suite result-file-to-csv evaluation-kcsan_dcf8e5633e2e
phoronix-test-suite result-file-to-csv evaluation-scalability
  • analyze the data, execute python3 /root/scripts/analyze.py (new added in the 1-evaluation), there will be a table /root/scripts/result.csv outputted, including the data, and the overhead compared to the vanilla results. It can be read by any types of excel/google sheets like tools.

results like the table

|          | perf-bench  | OSBench  | Timed Linux Kernel Compilation  | XZ Compression | LAME MP3 Encoding | Perl Benchmarks  | OpenSSL |average|
|----------|-------------|----------|---------------------------------|----------------|-------------------|------------------|---------|-------|
| vanilla  |             |          |                                 |                |                   |                  |         |       |
| overhead |             |          |                                 |                |                   |                  |         |       |
| cve-xxxx |             |          |                                 |                |                   |                  |         |       |
| overhead | x%          | x%       |                                 |                |                   |                  |         |X%     |

the overhead rows present the overhead compared to the vanilla results, the last column is the average overhead.

We present 5 results related to the 5 types of BPF programs, after that scalability shows the total overhead when 5 types of BPF programs run concurrently.

Due to the qemu experimental environment, the results may be partially different from the results of the paper, commonly found in system calls and networks

generate a new BPF program to prevent the vulnerability from being triggered.

more examples are in user guidance.

There are mainly 4 steps to generate BPF program from scratch, we take a publicly available and fixed vulerability, https://syzkaller.appspot.com/bug?id=6312526aba5beae046fdae8f00399f87aab48b12 as example

1. get the bug report

First of all, evaluators need get bug report from sanitized kernel, we have prepared the proof-of-concept in the environment.

Evaluators can boot up sanitized kernel by running run-kasan.sh, then execute ./scripts/test-kasan-631252aba.sh, the bug report will be export to the terminal 1. after that, evaluators need to copy the bug report and paste in the file kasan-631252aba.report.

as shown in 1-evaluation/add_new_BPF/kasan-631252aba.report

[   17.390082] ==================================================================
[   17.390770] BUG: KASAN: use-after-free in filp_close+0x21/0xa0
[   17.391349] Read of size 8 at addr ffff88800d847678 by task poc/342
[   17.391962] 
[   17.392129] CPU: 1 PID: 342 Comm: poc Not tainted 5.15.0ebpf-detector+ #83
[   17.392826] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.15.0-1 04/01/204
[   17.393669] Call Trace:
[   17.393928]  dump_stack_lvl+0x46/0x5a

2. extract critical information and generate program

According to the error dependant policies in section 5.3 Use-After-Free Policy, and the error independant policies in section 6 Error-independent Mechanisms.

PET needs to get the free position than may conduct dangling pointers from bug report, including function that calls memory free function, and offset from call kfree to function start. Evaluators can execute python3 extract-uaf.py kasan-631252aba.report to get extract the critical information.

$ python3 extract-uaf-report.py kasan-631252aba.report 
BUG: KASAN: use-after-free in filp_close+0x21/0xa0
 put_fs_context+0x1ac/0x280
 put_fs_context


$ python3 extract-uaf-binary.py put_fs_context
put_fs_context: 0xffffffff81348670
the function that call: 0xffffffff8134875c
offset: 0xec

after that, evaluator take the critical information as input, execute python3 gen-uaf.py kasan-631252aba function offset.

2 files will be generated in the directory ./linux-5.15-vulns/samples/bpf, detector_kasan-631252aba-evaluation.bpf.c and detector_kasan-631252aba-evaluation.c

$ python3 gen-uaf.py  put_fs_context  kasan-631252aba  0xec  <path-to-kernel>/sample/bpf

3. compile the BPF program

first of all, evaluators needs to add compile instructions in the /root/linux-5.15-vulns/samples/bpf/Makefile.

  • tprogs-y+=detector_kasan-631252aba-evaluation
  • detector_kasan-631252aba-evaluation-objs+=detector_kasan-631252aba-evaluation,o
  • always-y+=detector_kasan-631252aba-evaluation.bpf.o

for easy, we have already add them in the Makefile, and pre-compiled them because of the very complex compilation dependencies

4. functional tests

similar the the previous functional evaluation, evaluators can run /root/linux-5.15-vulns/samples/bpf/detector_kasan-631252aba-evaluation in terminal 2

and execute proof-of-concept in /root/test-kasan-631252aba in the terminal 1, results will be presented in terminal 2, dangling pointer will be quarantined.

more templates

templates