From c29157e78df7fa335c56d0d7f2cca7dc50bfffd6 Mon Sep 17 00:00:00 2001 From: Alice Frosi Date: Tue, 2 May 2023 17:21:57 +0200 Subject: seitan: refactor operations Refactoring: - rename do_operations to eval and reduce the number of arguments - create macro HANDLE_OP - rename all functions with op_*(operation name) - exposed the op_* functions in the operations.h Fixes: - use pread for op_load --- operations.h | 38 +++++++++++++++++++++++++++++++++++--- 1 file changed, 35 insertions(+), 3 deletions(-) (limited to 'operations.h') diff --git a/operations.h b/operations.h index ecb6414..011369a 100644 --- a/operations.h +++ b/operations.h @@ -9,8 +9,23 @@ #include #include +#include "common/gluten.h" +#include "common/util.h" + #define STACK_SIZE (1024 * 1024 / 8) #define NS_NUM (sizeof(enum ns_type)) +#define HANDLE_OP(code, call, type) \ + case code: \ + do { \ + int res = call(req, notifier, g, &op->op.type); \ + if (res == 0) \ + (op)++; \ + else if (res == -1) \ + (op) = NULL; \ + else \ + (op) += res; \ + } while (0); \ + break struct arg_clone { const struct op_call *args; @@ -20,7 +35,24 @@ struct arg_clone { }; int do_call(struct arg_clone *c); -int do_operations(struct gluten *g, struct op operations[], - struct seccomp_notif *req, - unsigned int n_operations, int notifyfd); +void eval(struct gluten *g, struct op *ops, const struct seccomp_notif *req, + int notifier); +int op_call(const struct seccomp_notif *req, int notifier, struct gluten *g, + struct op_call *op); +int op_block(const struct seccomp_notif *req, int notifier, struct gluten *g, + struct op_block *op); +int op_return(const struct seccomp_notif *req, int notifier, struct gluten *g, + struct op_return *op); +int op_continue(const struct seccomp_notif *req, int notifier, struct gluten *g, + void *); +int op_inject(const struct seccomp_notif *req, int notifier, struct gluten *g, + struct op_inject *op); +int op_inject_a(const struct seccomp_notif *req, int notifier, struct gluten *g, + struct op_inject *op); +int op_cmp(const struct seccomp_notif *req, int notifier, struct gluten *g, + struct op_cmp *op); +int op_resolve_fd(const struct seccomp_notif *req, int notifier, + struct gluten *g, struct op_resolvedfd *op); +int op_load(const struct seccomp_notif *req, int notifier, struct gluten *g, + struct op_load *load); #endif /* ACTIONS_H */ -- cgit v1.2.3