Код: Выделить всё
SYSCALL_DEFINE5(renameat2, int, olddfd, const char __user *, oldname,
int, newdfd, const char __user *, newname, unsigned int, flags)
{
return do_renameat2(olddfd, getname(oldname), newdfd, getname(newname),
flags);
}
Код: Выделить всё
getname
С помощью getname* , я получаю много выходных данных, означающих, что моя программа BPF действительно выполняется. Хотя при вызове «renameat2» (например, при использовании команды linux mv) я вообще не получаю никаких результатов.
По сути, это программа, которую я использую. используется в настоящее время, который не вызывается при использовании команды mv:
Код: Выделить всё
SEC("fentry/getname_flags")
int BPF_PROG(hijack_getname, char *filename) {
uid_t uid = bpf_get_current_uid_gid() & 0xFFFFFFFF;
if (uid == 1002) { //hardcoded uid
bpf_printk(" [%s]", filename);
}
}
Как я уже сказал, я также пробовал использовать kprobe и fexit. Мне не удается подключиться к strncpy_from_user, не получая при этом странных ошибок о «Os: 22 — неверный аргумент».
Я действительно не могу понять, что происходит, поэтому любые помощь будет оценена по достоинству :,)
Подробнее здесь: https://stackoverflow.com/questions/792 ... -renameat2