관리-도구
편집 파일: aux_syscalls.stp
# arch-specific requests of ptrace ___________________________ # = like tapset/x86_64/syscalls.stp but without PTRACE_ARCH_PRCTL # %{ #ifndef PTRACE_SYSEMU # define PTRACE_SYSEMU 31 #endif #ifndef PTRACE_SYSEMU_SINGLESTEP # define PTRACE_SYSEMU_SINGLESTEP 32 #endif #ifndef PTRACE_SINGLEBLOCK # define PTRACE_SINGLEBLOCK 33 #endif // Get _stp_val_array and _stp_lookup_* definitions. #include "linux/syscalls-common.h" static const _stp_val_array _stp_arch_ptrace_request_list[] = { V(PTRACE_GETREGS), V(PTRACE_SETREGS), V(PTRACE_GETFPREGS), V(PTRACE_SETFPREGS), V(PTRACE_GETFPXREGS), V(PTRACE_SETFPXREGS), V(PTRACE_OLDSETOPTIONS), V(PTRACE_GET_THREAD_AREA), V(PTRACE_SET_THREAD_AREA), V(PTRACE_SYSEMU), V(PTRACE_SYSEMU_SINGLESTEP), V(PTRACE_SINGLEBLOCK), {0, NULL} }; %} function __arch_ptrace_request_str:string(request:long) %{ /* pure */ _stp_lookup_str(_stp_arch_ptrace_request_list, (unsigned long)STAP_ARG_request, STAP_RETVALUE, MAXSTRINGLEN); %} function _arch_ptrace_argstr:string(request:long, pid:long, addr:long, data:long) { if (request == @const("PTRACE_GETREGS") || request == @const("PTRACE_SETREGS") || request == @const("PTRACE_GETFPREGS") || request == @const("PTRACE_SETFPREGS") || request == @const("PTRACE_GETFPXREGS") || request == @const("PTRACE_SETFPXREGS")) return sprintf("%s, %d, %#x, %p", __arch_ptrace_request_str(request), pid, addr, data) if (request == @const("PTRACE_SYSEMU") || request == @const("PTRACE_SYSEMU_SINGLESTEP") || request == @const("PTRACE_SINGLEBLOCK")) return sprintf("%s, %d, %#x, %s", __arch_ptrace_request_str(request), pid, addr, _signal_name (data)) if (request == @const("PTRACE_OLDSETOPTIONS")) return sprintf("PTRACE_OLDSETOPTIONS, %d, %#x, %s", pid, addr, _ptrace_options_str(data)) if (request == @const("PTRACE_GET_THREAD_AREA") || request == @const("PTRACE_SET_THREAD_AREA")) return sprintf("%s, %d, %d, %p", __arch_ptrace_request_str(request), pid, __int32(addr), data) } function _ptrace_return_arch_prctl_addr:long(request:long, addr:long, data:long) { return 0 } %{ #include <asm/ldt.h> %} function _struct_user_desc_u:string(uaddr:long) %{ /* pure */ struct user_desc ud; char *ptr = (char *)(uintptr_t)STAP_ARG_uaddr; if (ptr == NULL) strlcpy (STAP_RETVALUE, "NULL", MAXSTRINGLEN); else { if (_stp_copy_from_user((char*)&ud, ptr, sizeof(struct user_desc)) == 0) { snprintf(STAP_RETVALUE, MAXSTRINGLEN, "{entry_number=%u, base_addr=%lu, limit=%u, seg_32bit=%u, contents=%u, " "read_exec_only=%u, limit_in_pages=%u, seg_not_present=%u, useable=%u}", ud.entry_number, (unsigned long)ud.base_addr, ud.limit, ud.seg_32bit, ud.contents, ud.read_exec_only, ud.limit_in_pages, ud.seg_not_present, ud.useable); } else { snprintf(STAP_RETVALUE, MAXSTRINGLEN, "0x%lx", (unsigned long)ptr); } } %}