forked from polygraphene/DirtyPipe-Android
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
84 lines (64 loc) · 2.48 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
CC=aarch64-linux-android31-clang
CXX=aarch64-linux-android31-clang++
STRIP=llvm-strip
CFLAGS=-O2 $(CPPFLAGS)
ADB=adb
MYMOD_COPY=../../p6/kernel/out/android-gs-pixel-5.10/dist/mymod.ko
D=/data/local/tmp
OBJS=dirtypipe-android.o elf-parser.o stage1.o stage2-payload-include.S
VERSION=1.0.3
build: dirtypipe-android mymod.ko
dirtypipe-android: $(OBJS) Makefile stage2-payload
$(CC) $(CFLAGS) -Wall -o $@ $(OBJS)
dirtypipe-android.o: dirtypipe-android.c Makefile stage2-symbol.h
$(CC) $(CFLAGS) -Os -c -o $@ $<
elf-parser.o: elf-parser.c Makefile
$(CC) $(CFLAGS) -Os -c -o $@ $<
stage1.o: stage1.S Makefile include.inc
$(CC) $(CPPFLAGS) -c -o $@ $<
stage2.o: stage2.S Makefile include.inc
$(CC) $(CPPFLAGS) -nostdlib -c -o $@ $<
stage2-c.o: stage2-c.c Makefile
$(CC) $(CPPFLAGS) -Os -nostdlib -c -o $@ $<
stage2: stage2-c.o stage2.o stage2.lds Makefile
$(CC) $(CPPFLAGS) -T stage2.lds -nostdlib -nostartfiles -static -o $@ stage2-c.o stage2.o
# Must be smaller than 4096 bytes
stage2.text: stage2 Makefile
aarch64-linux-gnu-objcopy -O binary -j .text $< $@
stage2-symbol.h: stage2 Makefile
echo -n "unsigned long stage2_libname_addr = 0x" > $@
(nm $< | grep -e ' T libname'$ | cut -f 1 -d " " | tr -d $$'\n'; echo "UL - 0x2000UL;") >> $@ || rm $@
# Must be smaller than 4096 bytes
modprobe-payload: modprobe-payload.c Makefile
$(CC) $(CPPFLAGS) -Os -nostartfiles -o $@ $< -llog
$(STRIP) $@
mymod.ko: $(MYMOD_COPY)
cp $(MYMOD_COPY) mymod.ko
# Page 1: stage2.text (Up to 1 page)
# Page 2: modprobe-payload (Up to 1 page)
# Page 3-6: mymod.ko (Up to 4 page)
stage2-payload: stage2.text modprobe-payload mymod.ko Makefile
test -z "$$(find stage2.text -size +4096c)"
test -z "$$(find modprobe-payload -size +4096c)"
test -z "$$(find mymod.ko -size +16384c)"
cp stage2.text $@
truncate -s 4096 $@
cat modprobe-payload >> $@
truncate -s $(shell echo $$(( 4096 * 2 ))) $@
cat mymod.ko >> $@
truncate -s $(shell echo $$(( 4096 * 6 ))) $@
stage2-payload-include.o: stage2-payload-include.S stage2-payload Makefile
$(CC) -c -o $@ $<
clean:
-rm dirtypipe-android.o elf-parser.o stage1.o stage2-payload dirtypipe-android
-rm stage2.text stage2 stage2-c.o stage2.o
-rm stage2-symbol.h
-rm modprobe-payload
### INSTALL ###
install: dirtypipe-android startup-root magisk/busybox
$(ADB) push dirtypipe-android startup-root magisk/busybox $(D)
$(ADB) shell chmod 755 $(D)/dirtypipe-android $(D)/startup-root $(D)/busybox
run: install
$(ADB) shell $(D)/dirtypipe-android
release: build
./release.sh $(VERSION)