Seccomp_unotify не может перехватить системный вызов более одного разаLinux

Ответить
Anonymous
 Seccomp_unotify не может перехватить системный вызов более одного раза

Сообщение Anonymous »

Я пытаюсь использовать libseccomp для перехвата системных вызовов и попадаю в неприятности. Как следует из названия, супервизор может перехватить только первый getpid(). Кажется, что fd больше не действителен (не уверен) после первого getpid(). Ошибка: 22: Неверный аргумент.

Код: Выделить всё

#include 
#include 
#include 
#include 
using namespace std;

int main()
{
int pp[2];
pipe(pp);
pid_t pid = fork();
if(pid == 0)
{
//target
close(pp[0]);
scmp_filter_ctx ctx = seccomp_init(SCMP_ACT_ALLOW);
seccomp_rule_add(ctx, SCMP_ACT_NOTIFY, SCMP_SYS(getpid), 0);
seccomp_load(ctx);
int fd = seccomp_notify_fd(ctx);
write(pp[1], &fd, sizeof(fd));
cout 

Подробнее здесь: [url]https://stackoverflow.com/questions/78242085/seccomp-unotify-cant-catch-syscall-more-than-once[/url]
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Linux»