1 #include <dbi_kprobes.h>
2 #include <dbi_kprobes_deps.h>
4 #include "us_proc_inst.h"
5 #include "us_slot_manager.h"
8 #include "filters/filters_core.h"
11 ******************************************************************************
13 ******************************************************************************
20 static int entry_handler_pf(struct kretprobe_instance *ri, struct pt_regs *regs)
22 struct pf_data *data = (struct pf_data *)ri->data;
24 #if defined(CONFIG_X86)
25 data->addr = read_cr2();
26 #elif defined(CONFIG_ARM)
27 data->addr = regs->ARM_r0;
29 #error this architecture is not supported
35 /* Detects when IPs are really loaded into phy mem and installs probes. */
36 static int ret_handler_pf(struct kretprobe_instance *ri, struct pt_regs *regs)
38 struct task_struct *task;
39 struct sspt_proc *proc;
42 * Because process threads have same address space
43 * we instrument only group_leader of all this threads
45 task = current->group_leader;
46 if (task->flags & PF_KTHREAD)
49 proc = sspt_proc_get_by_task(task);
53 task = check_task(task);
55 proc = sspt_proc_get_new(task);
62 if (proc->first_install) {
64 page = ((struct pf_data *)ri->data)->addr & PAGE_MASK;
65 sspt_proc_install_page(proc, page);
67 sspt_proc_install(proc);
73 static struct kretprobe pf_kretprobe = {
74 .entry_handler = entry_handler_pf,
75 .handler = ret_handler_pf,
76 .data_size = sizeof(struct pf_data)
82 ******************************************************************************
84 ******************************************************************************
87 static void recover_child(struct task_struct *child_task, struct sspt_proc *proc)
89 sspt_proc_uninstall(proc, child_task, US_DISARM);
90 dbi_disarm_urp_inst_for_task(current, child_task);
93 static void rm_uprobes_child(struct task_struct *task)
95 struct sspt_proc *proc = sspt_proc_get_by_task(current);
97 recover_child(task, proc);
101 /* Delete uprobs in children at fork */
102 static int ret_handler_cp(struct kretprobe_instance *ri, struct pt_regs *regs)
104 struct task_struct *task = (struct task_struct *)regs_return_value(regs);
106 if(!task || IS_ERR(task))
109 if(task->mm != current->mm) { /* check flags CLONE_VM */
110 rm_uprobes_child(task);
112 if (check_task(current)) {
113 struct sspt_proc *proc;
115 proc = sspt_proc_get_new(task);
116 sspt_proc_install(proc);
123 static struct kretprobe cp_kretprobe = {
124 .handler = ret_handler_cp,
130 ******************************************************************************
132 ******************************************************************************
135 /* Detects when target process removes IPs. */
136 static int mr_pre_handler(struct kprobe *p, struct pt_regs *regs)
138 struct sspt_proc *proc = NULL;
139 struct task_struct *task;
141 #if defined(CONFIG_X86)
142 task = (struct task_struct *)regs->EREG(ax);
143 #elif defined(CONFIG_ARM)
144 task = (struct task_struct *)regs->ARM_r0;
146 #error this architecture is not supported
149 if (task->tgid != task->pid) {
153 proc = sspt_proc_get_by_task(task);
155 int ret = sspt_proc_uninstall(proc, task, US_UNREGS_PROBE);
157 printk("failed to uninstall IPs (%d)!\n", ret);
160 dbi_unregister_all_uprobes(task);
167 static struct kprobe mr_kprobe = {
168 .pre_handler = mr_pre_handler
174 ******************************************************************************
176 ******************************************************************************
179 static int remove_unmap_probes(struct task_struct *task, struct sspt_proc *proc, unsigned long start, size_t len)
181 struct mm_struct *mm = task->mm;
182 struct vm_area_struct *vma;
184 if ((start & ~PAGE_MASK) || start > TASK_SIZE || len > TASK_SIZE - start) {
188 if ((len = PAGE_ALIGN(len)) == 0) {
192 vma = find_vma(mm, start);
193 if (vma && check_vma(vma)) {
194 struct sspt_file *file;
195 unsigned long end = start + len;
196 struct dentry *dentry = vma->vm_file->f_dentry;
198 file = sspt_proc_find_file(proc, dentry);
200 if (vma->vm_start == start || vma->vm_end == end) {
201 sspt_file_uninstall(file, task, US_UNREGS_PROBE);
204 unsigned long page_addr;
205 struct sspt_page *page;
207 for (page_addr = vma->vm_start; page_addr < vma->vm_end; page_addr += PAGE_SIZE) {
208 page = sspt_find_page_mapped(file, page_addr);
210 sspt_unregister_page(page, US_UNREGS_PROBE, task);
214 if (sspt_file_check_install_pages(file)) {
224 /* Detects when target removes IPs. */
225 static int unmap_pre_handler(struct kprobe *p, struct pt_regs *regs)
228 struct mm_struct *mm;
232 #if defined(CONFIG_X86)
233 mm = (struct mm_struct *)regs->EREG(ax);
234 start = regs->EREG(dx);
235 len = (size_t)regs->EREG(cx);
236 #elif defined(CONFIG_ARM)
237 mm = (struct mm_struct *)regs->ARM_r0;
238 start = regs->ARM_r1;
239 len = (size_t)regs->ARM_r2;
241 #error this architecture is not supported
244 struct sspt_proc *proc = NULL;
245 struct task_struct *task = current;
247 proc = sspt_proc_get_by_task(task);
249 if (remove_unmap_probes(task, proc, start, len)) {
250 printk("ERROR do_munmap: start=%lx, len=%x\n", start, len);
258 static struct kprobe unmap_kprobe = {
259 .pre_handler = unmap_pre_handler
264 int register_helper(void)
268 /* install kprobe on 'do_munmap' to detect when for remove user space probes */
269 ret = dbi_register_kprobe(&unmap_kprobe);
271 printk("dbi_register_kprobe(do_munmap) result=%d!\n", ret);
275 /* install kprobe on 'mm_release' to detect when for remove user space probes */
276 ret = dbi_register_kprobe(&mr_kprobe);
278 printk("dbi_register_kprobe(mm_release) result=%d!\n", ret);
279 goto unregister_unmap;
283 /* install kretprobe on 'copy_process' */
284 ret = dbi_register_kretprobe(&cp_kretprobe);
286 printk("dbi_register_kretprobe(copy_process) result=%d!\n", ret);
290 /* install kretprobe on 'do_page_fault' to detect when they will be loaded */
291 ret = dbi_register_kretprobe(&pf_kretprobe);
293 printk("dbi_register_kretprobe(do_page_fault) result=%d!\n", ret);
300 dbi_unregister_kretprobe(&cp_kretprobe);
303 dbi_unregister_kprobe(&mr_kprobe, NULL);
306 dbi_unregister_kprobe(&unmap_kprobe, NULL);
311 void unregister_helper(void)
313 /* uninstall kretprobe with 'do_page_fault' */
314 dbi_unregister_kretprobe(&pf_kretprobe);
316 /* uninstall kretprobe with 'copy_process' */
317 dbi_unregister_kretprobe(&cp_kretprobe);
319 /* uninstall kprobe with 'mm_release' */
320 dbi_unregister_kprobe(&mr_kprobe, NULL);
322 /* uninstall kprobe with 'do_munmap' */
323 dbi_unregister_kprobe(&unmap_kprobe, NULL);
326 int init_helper(void)
329 addr = swap_ksyms("do_page_fault");
331 printk("Cannot find address for page fault function!\n");
334 pf_kretprobe.kp.addr = (kprobe_opcode_t *)addr;
336 addr = swap_ksyms("copy_process");
338 printk("Cannot find address for copy_process function!\n");
341 cp_kretprobe.kp.addr = (kprobe_opcode_t *)addr;
343 addr = swap_ksyms("mm_release");
345 printk("Cannot find address for mm_release function!\n");
348 mr_kprobe.addr = (kprobe_opcode_t *)addr;
350 addr = swap_ksyms("do_munmap");
352 printk("Cannot find address for do_munmap function!\n");
355 unmap_kprobe.addr = (kprobe_opcode_t *)addr;
360 void uninit_helper(void)