Skip to content

DemDing/confTainter

 
 

Repository files navigation

confTainter

confSysTaint is based on LLVM IR, it analyzes the control and data dependency starting from the specified configuration variable(s)

Data flow

  • basic LLVM "Use" support
    截屏2022-09-03 15 27 06
  • Field sensitive analysis
    截屏2022-09-03 15 44 43
  • Inter-procedure (with pointer)
    截屏2022-09-03 15 53 39
    截屏2022-09-03 16 02 01
  • Our extended data-flow (phi-node)
    截屏2022-09-03 16 06 28
    • How to formaly determine if a phi-node will be tainted
      Given a phiNode like:
         phi i32 [ %5, %bb1.i ], [ 0, %bb1 ]
                    pre_node      pre_node2
      
      we check if: 截屏2022-09-03 16 07 53

Control flow

Formaly define how the control flow:

  • Control Dependency: A block Y is control dependent on block X if and only if: Y post-dominates at least one but not all successors of X.
    • Transitivity:if A control dependent on B, B control dependent on C, then A control dependent on C.

An example, where the yellow square indicats the complicated code structures that motivate the use of the formal definition.
截屏2022-09-03 16 39 03

Usage

Dependency

Build

cd tainter
cmake -DCMAKE_CXX_COMPILER=/usr/bin/clang++-10 -DCMAKE_C_COMPILER=/usr/bin/clang-10 -DLLVM_DIR=/usr/lib/llvm-10/cmake . 
make

Run

cd test/demo
../../tainter test.bc test-var.txt

For real DBMS, use gllvm to obtain the .bc file (e.g., mysqld.bc).

Check results

cat test-records.dat

Example result

Tainted Functions (group by Caller-Functions): 

		Clone_Handle::open_file <------------ func-1 of "srv_unix_file_flush_method"
				Clone_Task_Manager::set_error ----- Tainted Function.

		Clone_Snapshot::update_block_size <-- func-2 of "srv_unix_file_flush_method"
				os_event_set -------------------\ 
				pfs_unlock_mutex_v1              |_ Tainted Function.
				sync_array_object_signalled      |
				ut_dbg_assertion_failed --------/

		Double_write::sync_page_flush <------ func-3 of "srv_unix_file_flush_method"
				__clang_call_terminate ---------\ 
				buf_page_io_complete             |-- Tainted Function.
				fil_flush ----------------------/
        
    ...

Specify the entry configuration variable

  • SINGLE CONF_VAR_NAME global variable with basic type (int, bool, etc.)
  • STRUCT CONF_VAR_STRUCT.FIELD_NAME global struct with field
  • CLASS CONF_VAR_CLASS.FIELD_NAME global class with field
  • FIELD CONF_VAR_TPYE.FIELD_COUNT any field of specified type, for example, use FIELD some_type.2 to make some_type.field_C as the entry point.
    STRUCT some_type{
       int field_A;
       bool field_B;
       float field_C;
    }
    

How to debug:

  1. Make sure you have use the right compilation options: -O0-fno-discard-value-names-g; if you want the PhiNode analysis, also use these two options.
  2. Make sure the specified configuration variable name is right.
    • Check if it exists in source code via simple search grep CONF_NAME /dir/of/src.
    • Check if it has been compiled into the target .bc file grep CONF_VAR_NAME /dir/to/target.ll.
  3. If the entry you specified in *-parameter.txt does not produce any results, try to find if the configuration variable is rightly in *.bc
    ########
    ## Example empty result: content of "*-record.dat"
    ########
    
    GlobalVariable Name: System_variables.45  Offset: 45 
    
    Caller Functions: 
    
    Tainted Functions (group by Caller-Functions): 
    
    
    Called Functions: 
    
    Called Chain:
    
    Related GlobalVariables: 
    
    • For example, if you use FIELD System_variables.45 to specify configuration System_variables.preload_buff_size, then you need to make sure command
      grep "getelementptr inbounds %struct.System_variables" mysqld.ll
      
      produces the right results like %xx = getelementptr inbounds %struct.System_variables, %struct.System_variables* %xx, i64 0, i32 45, !dbg !xxx where i64 0, i32 45 must appear.
    • If you use SINGLE srv_unix_file_flush_method to specify configuration innodb_flush_method, things will be easier: use
      grep "srv_unix_file_flush_method" mysqld.ll
      
      to see if something like %xx = load i32, i32* @srv_unix_file_flush_method, align 4, !dbg xxxx appears.
    • If all the stdout log shows that all the DIRECT use of STRUCT xxx.yyy is [OK, PASS], it may be because xxx is not global, or some other reasons. Try to use FIELD xxx.0 (say yyy is the very first field of xxx)

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 95.2%
  • Makefile 2.1%
  • C 1.4%
  • CMake 1.3%