-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathimplementation.tex
87 lines (73 loc) · 4.22 KB
/
implementation.tex
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
84
85
86
87
\chapter{Implementation}
Using \emph{QEMU} makes \emph{S$^{2}E$} capable of performing whole sysetm
symbolic execution on all architectures supported by \emph{QEMU}. Since
\emph{CRAX} has the knowledge of exploiting linux x86 applications,
\href{http://www.android-x86.org/}{Android x86} is chosen to be the entrypoint
to exploit Android.
\section{Android x86}
Another reason to choose Android x86 is that it provides direct \emph{QEMU}
support. By building Android x86 with ``make iso\_img'', it returns an
installation iso image that can be used to install Android on any storage
media, just like any other regular linux distribution does.
Figure~\ref{fig:android-x86-installation} shows the first step of the
installation. Normally, it takes around five steps to finish installation. The
highlighted option in Figure~\ref{fig:android-x86-installation} is a quick path
that I built for one-step installation.
\begin{figure}[!ht]
\includegraphics[width=0.7\textwidth]{android-x86-installation}
\caption{Android x86 Installation ISO Image}
\label{fig:android-x86-installation}
\end{figure}
There are two command line executables pre-embedded into to Android x86 source
tree for app testing. The first one is \textbf{s2ecmd}, which is mainly used to
toggle switch of single path concolic execution. The second one is
\textbf{symfile}, see Listing~\ref{lst:symfile.c} on
page~\pageref{lst:symfile.c}. \textbf{symfile} is used to mark a file content
as symbolic source as a input of app testing. Our version of \textbf{symfile}
is different from the one provided by \textbf{s2ecmd}, which required the
target file to be stored in a ramdisk. Our \textbf{symfile} will first map the
target file into a bunch of memory space by using \textbf{mmap}. Thus,
accessing data from the file will be accessing data from the mapped memory
space.
\subsection{Scenario 1 - propagate underneath Dalvik VM}
Android x86 suffers from the same kind of vulnerabilities just like any other
system that runs on the x86 architecture does, stack overflow, heap overflow,
format string vulnerability, etc. Any app that leverages the power of native
library becomes a potential threat. To prove that \emph{CRAXDroid} is able to
generate exploit automatically on Android x86, a vulnerable app is constructed
intentionally as shown in Listing\ref{lst:vulnapp.java} and
Listing\ref{lst:vulnapp.c}.
The vulnerable app contains a stack overflow vulnerability caused by improper
use of the function \textbf{strcpy}. \textbf{strcpy} is known to cause
stack overflow if boundary checking is not done properly. For example, copying
content of a buffer with 10 bytes to a buffer with only 5 bytes would overwrite
the stack by 5 bytes. Combining with the nature of x86 architecture, which
store instruction pointers (EIP) on the stack as shown in
Figure~\ref{fig:x86-stack-layout}, attackers would be able to forge the EIP
value and intrude the running process.
\begin{figure}[!ht]
\includegraphics[width=\textwidth]{x86-stack-layout}
\caption{x86 stack layout}
\label{fig:x86-stack-layout}
\end{figure}
\emph{CRAXDroid} first maps a local file into memory by using \textbf{mmap} and
marks the part of the memory as symbolic to keep track of the flow of the file
content. After the vulnerable app is launched, the target file is opened and
read by the loaded native library. Since the file is mapped to a chunk of
memory, the content would be read from the chunk of memory instead of physical
hard drive. Once the process retrieves the saved instruction pointer from the
returning stack frame, a pre-deployed sensor set by \emph{CRAXDroid} would
check if the EIP is contaminated by the symbolic input and trigger the
progress of exploit generating if the examination goes true.
\subsection{Scenario 2 - propagate through Dalvik VM}
Scenario 2 is implemented slightly different from scenario 1. The source code
is listed in Listing\ref{lst:vulnapp2.java} and Listing\ref{lst:vulnapp2.c}.
The input file is opened and read into a buffer in the Dalvik VM and passed to
the native library through JNI. By successfully generating exploit, we could
prove that it is possible to exploit a app by giving bad input from the app
layer.
%\section{ARM}
%\subsection{Raspberry Pi}
%\subsection{Linux ARM}
%\subsection{Android ARM}
% vim: sw=2 sts=2 et