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
|
probe begin
{
# First we'll print the value of cwd/exe for the current task.
try
{
task = task_current()
path = task_cwd_path(task)
printf("current cwd: %s\n", fullpath_struct_path(path))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
try
{
file = task_exe_file(task)
printf("current exe: %s\n", fullpath_struct_file(task, file))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
# Now print the value of cwd/exe for our target pid. Note that at
# this point, the target exe path will still be stapio - the exec
# hasn't happened yet.
try
{
task = pid2task(target())
path = task_cwd_path(task)
printf("target cwd: %s\n", fullpath_struct_path(path))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
try
{
file = task_exe_file(task)
printf("target exe: %s\n", fullpath_struct_file(task, file))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
# Let's try using a task pointer of 0, which should fail.
try
{
task = 0
path = task_cwd_path(task)
printf("path: %p\n", path)
printf("%s\n", fullpath_struct_path(path))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
try
{
file = task_exe_file(task)
printf("file: %p\n", file)
printf("%s\n", fullpath_struct_file(task, file))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
# Now let's try using a task pointer of -1, which should also
# fail.
try
{
task = -1
path = task_cwd_path(task)
printf("%s\n", fullpath_struct_path(path))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
try
{
file = task_exe_file(task)
printf("%s\n", fullpath_struct_file(task, file))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
}
probe syscall.geteuid, syscall.getuid
{
# Now print the value of cwd/exe for our target pid. At this
# point, we should be executing 'whoami', since stapio should have
# forked, then exec'ed 'whoami'.
if (pid() != target()) next
try
{
task = task_current()
path = task_cwd_path(task)
printf("current cwd: %s\n", fullpath_struct_path(path))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
try
{
file = task_exe_file(task)
printf("current exe: %s\n", fullpath_struct_file(task, file))
}
catch (msg) {
printf("ERROR: %s\n", msg)
}
exit()
}
|