Skip to content

Draw basic flow diagram of methods in smali file based on unconditional jump and conditional jump instructions.

License

Notifications You must be signed in to change notification settings

anivs/DrawFlowDiagramOfSmaliMethods

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

DrawFlowDiagramOfSmaliMethods

when analysing an APK in reverse process, we usually use apktool(http://ibotpeaches.github.io/Apktool/) to decompile the APK and then get smali codes. Although some tools,such as dex-to-jar, can convert smali codes to java codes which is more readable, those tools may not work if the method is complicate enough or confused. In this case, you can use this project to draw the basic flow diagram of method to understand the execution flow quickly.

The flow diagram is based on unconditional jump(goto) and conditional jump(if) instructions.

##Dependency

  1. python2.7

##Platform

  • You can run this program on Linux.
  • As for windows, you can change the variable DOT_PATH in drawFlowDiagramOfSmaliMethods.py.
    Since output file name is named by method's name correspondingly, if method's name contains illegal characters of file name, the flow diagram of this method will not be generated.

##Usage (Make sure you install python2.7 and Graphviz before running this program)

  • type "python drawFlowDiagramOfSmaliMethods.py -h" in cmdline will show help message.
  1. -s smali_file_path is indispensable, it specifies which smali file you want to parse.
  2. -f {png,jpg,svg} specifies the format of output picture file containing flow diagram generated
  3. -m methods_to_draw specifies the methods which you want to draw flow diagrams of. Different methods split with #, such as func#func1\(I\)Z. If you doesn't specify this parameter,it will draw all methods' flow diagrams.
  4. -o output_dir specifies the directory of output flow diagrams. Defult is current directory.

Example:

  • python drawFlowDiagramOfSmaliMethods.py -s Check.smali //generate flow diagrams of all methods in Check.smali
  • python drawFlowDiagramOfSmaliMethods.py -s Check.smali -f png -m check -o /home/cpf/output

##Output Flow Diagrams 1.example 1

2.example 2

Note:

  • The numbers in the diagram increasing from top to bottom are the line numbers of instructions.
    Figure legends:
    1.Yellow rectangle indicates return instruction.
    2.Orange edge indicates unconditional jump
    3.Red edge indicates conditional jump if condition is false. That means it will execute all instructions between from node and end node
    4.Green edge indicates conditional jump if condition is true

About

Draw basic flow diagram of methods in smali file based on unconditional jump and conditional jump instructions.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Smali 98.9%
  • Python 1.1%