about summary refs log tree commit diff
path: root/fs-tracer-ebpf/src/syscalls/open.rs
blob: 732212d9fa0bceadf49ae9e7f0083c9fd2f47edf (plain) (blame)
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
use core::{mem::{self, size_of}, ptr};

use aya_bpf::{helpers::{bpf_probe_read_kernel, gen}, cty::{c_char, c_int, c_long, c_void}, maps::PerCpuArray};

use crate::{*, vmlinux::{files_struct, umode_t}};
const AT_FDCWD: c_int = -100;
const MAX_PATH: usize = 4096;

#[repr(C)]
pub struct Buffer {
    pub buf: [u8; MAX_PATH],
}

#[map]
static mut BUF: PerCpuArray<Buffer> = PerCpuArray::with_max_entries(1, 0);

pub fn handle_sys_open(ctx: TracePointContext, syscall_type: SyscallType) -> Result<c_long, c_long> {
    //info!(&ctx, "called");
    match syscall_type {
        SyscallType::Enter => unsafe { handle_sys_open_enter(ctx) },
        SyscallType::Exit => unsafe { handle_sys_open_exit(ctx) },
    }
}

unsafe fn handle_sys_open_enter(ctx: TracePointContext) -> Result<c_long, c_long> {
    //info!(&ctx, "handle_sys_open_enter start");
    let mut task = bpf_get_current_task_btf() as *mut task_struct;

    //info!(&ctx, "test: {}", (*files).next_fd);
    let pid = (*task).fs as *const fs_struct;
    let uwu = (*pid).pwd;
    let ra = uwu.dentry as *const dentry;
    let ma = str::from_utf8_unchecked(&(*ra).d_iname);
    let buf = get_buf()?;

    #[repr(C)]
    #[derive(Clone, Copy)]
    struct OpenAtSyscallArgs {
        dfd: c_int,
        filename: *const c_char,
        flags: c_int,
        mode: umode_t,
    }

    //TODO: Check if the flags is relative

    let args = *ptr_at::<OpenAtSyscallArgs>(&ctx, 16).unwrap_unchecked();

    if args.dfd == AT_FDCWD {
        info!(&ctx, "relative call!");
        let pwd = get_task_pwd(task)?;
        
        info!(&ctx, "DEBUGGG: {}", pwd);

        let filename = unsafe {
            core::str::from_utf8_unchecked(bpf_probe_read_user_str_bytes(
                args.filename as *const u8,
                &mut buf.buf,
            ).unwrap_unchecked())
        };

        info!(
            &ctx,
            "Tf {} {} dfd: {}",
            2,//ma
            filename,
            args.dfd
        );
    }
   /*else {
        info!(&ctx, "not relative call!");
          /*   let files = (*x).files;
        let fdt = (*files).fdt;
        let fdd = (*fdt).fd;*/
        //info!(&ctx, "pid from ctx: {}", ctx.pid());
        //info!(&ctx, "pid from task {}", (*task).pid);

        let files = bpf_probe_read_kernel(&(*task).files)?;
        let fdt = bpf_probe_read_kernel(&(*files).fdt)?;
        let fdarr = bpf_probe_read_kernel(&(*fdt).fd)?;
        info!(&ctx, "wuit: {}", args.dfd);
        info!(&ctx, "test: {}", ctx.read_at::<c_int>(16).unwrap_unchecked());
        let fd = bpf_probe_read_kernel(&(*fdarr.offset(3)))?; //todo: get good fd here. conclusion, somehow we are getting the wrong fd. unsigned int?? but its signed idk
        let mut deb = bpf_probe_read_kernel(&(*fd).f_path)?;
        let rwada = bpf_probe_read_kernel(&deb.dentry)?;
        let iname = bpf_probe_read_kernel_str_bytes(&(*rwada).d_iname as *const u8, &mut buf.buf)?;
        let xaxwaxa = str::from_utf8_unchecked(iname);
        
        info!(&ctx, "DEBUGGG: {}", xaxwaxa);
        info!(&ctx, "dawdwawd");
        /*let file = (*fdd).add(args.dfd as usize * 8);
        let mut pat = (*file).f_path;
        //info!(&ctx, "path: {}", &pat)
        let aya_bpf_path_ptr: *mut aya_bpf::bindings::path = unsafe {
            mem::transmute::<&mut vmlinux::path, *mut aya_bpf::bindings::path>(&mut pat)
        };

        let mut buff = [0i8; 120];
    bpf_d_path( aya_bpf_path_ptr , &mut buff as *mut i8, 120);*/

        /*let pathname = pat.dentry;
        let mut huh = [0u8; 64];
        let xxxx = (*pathname).d_name.name;
        let aa = core::slice::from_raw_parts(xxxx, 10);
        info!(&ctx, "dawdwa: {}", str::from_utf8_unchecked(aa))*/
        //let filename = bpf_probe_read_kernel_str_bytes(xxxx.name, &mut huh);
    }*/



 
    Ok(0)
}

unsafe fn handle_sys_open_exit(ctx: TracePointContext) -> Result<c_long, c_long> {
    //info!(&ctx, "handle_sys_open_exit start");
    let ret = *ptr_at::<i64>(&ctx, 16).unwrap_unchecked(); //TODO: We cant use unwrap, thats why we couldnt use the aya helper fns

    let tgid = ctx.tgid();
    if let Some(syscall) = SYSCALL_ENTERS.get(&tgid) {
        let SyscallInfo::Write(mut syscall_write) = syscall;
        syscall_write.ret = ret;
        EVENTS.output(&ctx, &SyscallInfo::Write(syscall_write), 0);
        let _ = SYSCALL_ENTERS.remove(&tgid);
        return Ok(0);
    }

    Err(0)
}

unsafe fn get_task_pwd<'a>(task: *const task_struct) -> Result<&'a str, i64> {
    let buf2 = get_buf()?;
    let fs = bpf_probe_read_kernel(&(*task).fs)?;
    let pwd = bpf_probe_read_kernel(&(*fs).pwd)?;
   let rwada = bpf_probe_read_kernel(&pwd.dentry)?;
    let iname = bpf_probe_read_kernel_str_bytes(&(*rwada).d_iname as *const u8, &mut buf2.buf)?;
    let xaxwaxa = str::from_utf8_unchecked(iname);
    Ok(xaxwaxa)
}

unsafe fn get_buf<'a>() -> Result<&'a mut Buffer, i64>{
    let buf = unsafe {
        let ptr = BUF.get_ptr_mut(0).ok_or(1)?;
        &mut *ptr
    };
    Ok(buf)
}