cregit-Linux how code gets into the kernel

Release 4.11 arch/um/kernel/ptrace.c

Directory: arch/um/kernel
/*
 * Copyright (C) 2000 - 2007 Jeff Dike (jdike@{addtoit,linux.intel}.com)
 * Licensed under the GPL
 */

#include <linux/audit.h>
#include <linux/ptrace.h>
#include <linux/sched.h>
#include <linux/tracehook.h>
#include <linux/uaccess.h>
#include <asm/ptrace-abi.h>


void user_enable_single_step(struct task_struct *child) { child->ptrace |= PT_DTRACE; child->thread.singlestep_syscall = 0; #ifdef SUBARCH_SET_SINGLESTEPPING SUBARCH_SET_SINGLESTEPPING(child, 1); #endif }

Contributors

PersonTokensPropCommitsCommitProp
Christoph Hellwig2261.11%125.00%
Jeff Dike822.22%250.00%
Bodo Stroesser616.67%125.00%
Total36100.00%4100.00%


void user_disable_single_step(struct task_struct *child) { child->ptrace &= ~PT_DTRACE; child->thread.singlestep_syscall = 0; #ifdef SUBARCH_SET_SINGLESTEPPING SUBARCH_SET_SINGLESTEPPING(child, 0); #endif }

Contributors

PersonTokensPropCommitsCommitProp
Jeff Dike1745.95%250.00%
Christoph Hellwig1027.03%125.00%
Bodo Stroesser1027.03%125.00%
Total37100.00%4100.00%

/* * Called by kernel/ptrace.c when detaching.. */
void ptrace_disable(struct task_struct *child) { user_disable_single_step(child); }

Contributors

PersonTokensPropCommitsCommitProp
Bodo Stroesser1386.67%133.33%
Jeff Dike16.67%133.33%
Christoph Hellwig16.67%133.33%
Total15100.00%3100.00%

extern int peek_user(struct task_struct * child, long addr, long data); extern int poke_user(struct task_struct * child, long addr, long data);
long arch_ptrace(struct task_struct *child, long request, unsigned long addr, unsigned long data) { int i, ret; unsigned long __user *p = (void __user *)data; void __user *vp = p; switch (request) { /* read the word at location addr in the USER area. */ case PTRACE_PEEKUSR: ret = peek_user(child, addr, data); break; /* write the word at location addr in the USER area */ case PTRACE_POKEUSR: ret = poke_user(child, addr, data); break; case PTRACE_SYSEMU: case PTRACE_SYSEMU_SINGLESTEP: ret = -EIO; break; #ifdef PTRACE_GETREGS case PTRACE_GETREGS: { /* Get all gp regs from the child. */ if (!access_ok(VERIFY_WRITE, p, MAX_REG_OFFSET)) { ret = -EIO; break; } for ( i = 0; i < MAX_REG_OFFSET; i += sizeof(long) ) { __put_user(getreg(child, i), p); p++; } ret = 0; break; } #endif #ifdef PTRACE_SETREGS case PTRACE_SETREGS: { /* Set all gp regs in the child. */ unsigned long tmp = 0; if (!access_ok(VERIFY_READ, p, MAX_REG_OFFSET)) { ret = -EIO; break; } for ( i = 0; i < MAX_REG_OFFSET; i += sizeof(long) ) { __get_user(tmp, p); putreg(child, i, tmp); p++; } ret = 0; break; } #endif case PTRACE_GET_THREAD_AREA: ret = ptrace_get_thread_area(child, addr, vp); break; case PTRACE_SET_THREAD_AREA: ret = ptrace_set_thread_area(child, addr, vp); break; default: ret = ptrace_request(child, request, addr, data); if (ret == -EIO) ret = subarch_ptrace(child, request, addr, data); break; } return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Jeff Dike22571.66%640.00%
Paolo 'Blaisorblade' Giarrusso3711.78%213.33%
Al Viro216.69%16.67%
Renzo Davoli123.82%16.67%
Namhyung Kim103.18%213.33%
Christoph Hellwig61.91%16.67%
Bodo Stroesser20.64%16.67%
Richard Weinberger10.32%16.67%
Total314100.00%15100.00%


static void send_sigtrap(struct task_struct *tsk, struct uml_pt_regs *regs, int error_code) { struct siginfo info; memset(&info, 0, sizeof(info)); info.si_signo = SIGTRAP; info.si_code = TRAP_BRKPT; /* User-mode eip? */ info.si_addr = UPT_IS_USER(regs) ? (void __user *) UPT_IP(regs) : NULL; /* Send us the fake SIGTRAP */ force_sig_info(SIGTRAP, &info, tsk); }

Contributors

PersonTokensPropCommitsCommitProp
Jeff Dike7997.53%250.00%
Américo Wang11.23%125.00%
Simon Arlott11.23%125.00%
Total81100.00%4100.00%

/* * XXX Check PT_DTRACE vs TIF_SINGLESTEP for singlestepping check and * PT_PTRACED vs TIF_SYSCALL_TRACE for syscall tracing check */
int syscall_trace_enter(struct pt_regs *regs) { audit_syscall_entry(UPT_SYSCALL_NR(&regs->regs), UPT_SYSCALL_ARG1(&regs->regs), UPT_SYSCALL_ARG2(&regs->regs), UPT_SYSCALL_ARG3(&regs->regs), UPT_SYSCALL_ARG4(&regs->regs)); if (!test_thread_flag(TIF_SYSCALL_TRACE)) return 0; return tracehook_report_syscall_entry(regs); }

Contributors

PersonTokensPropCommitsCommitProp
Al Viro3042.86%116.67%
Jeff Dike2434.29%350.00%
Paolo 'Blaisorblade' Giarrusso1014.29%116.67%
Richard Weinberger68.57%116.67%
Total70100.00%6100.00%


void syscall_trace_leave(struct pt_regs *regs) { int ptraced = current->ptrace; audit_syscall_exit(regs); /* Fake a debug trap */ if (ptraced & PT_DTRACE) send_sigtrap(current, &regs->regs, 0); if (!test_thread_flag(TIF_SYSCALL_TRACE)) return; tracehook_report_syscall_exit(regs, 0); /* force do_signal() --> is_syscall() */ if (ptraced & PT_PTRACED) set_thread_flag(TIF_SIGPENDING); }

Contributors

PersonTokensPropCommitsCommitProp
Jeff Dike3550.72%571.43%
Al Viro2942.03%114.29%
Paolo 'Blaisorblade' Giarrusso57.25%114.29%
Total69100.00%7100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Jeff Dike39959.11%1341.94%
Al Viro8412.44%26.45%
Bodo Stroesser649.48%13.23%
Paolo 'Blaisorblade' Giarrusso527.70%39.68%
Christoph Hellwig395.78%26.45%
Renzo Davoli121.78%13.23%
Richard Weinberger101.48%39.68%
Namhyung Kim101.48%26.45%
Chris Wright20.30%13.23%
Linus Torvalds10.15%13.23%
Américo Wang10.15%13.23%
Simon Arlott10.15%13.23%
Total675100.00%31100.00%
Directory: arch/um/kernel
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.