Signed-off-by: Richard Guy Briggs <rgb@xxxxxxxxxx> --- lib/Makefile.am | 17 ++++++++++-- lib/lookup_table.c | 5 ++-- lib/test/lookup_test.c | 17 ++++++++++++ lib/uringop_table.h | 62 ++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 97 insertions(+), 4 deletions(-) create mode 100644 lib/uringop_table.h diff --git a/lib/Makefile.am b/lib/Makefile.am index f1107afabee6..7926ba50a78f 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -47,7 +47,7 @@ nodist_libaudit_la_SOURCES = $(BUILT_SOURCES) BUILT_SOURCES = actiontabs.h errtabs.h fieldtabs.h flagtabs.h \ fstypetabs.h ftypetabs.h i386_tables.h machinetabs.h \ msg_typetabs.h optabs.h ppc_tables.h s390_tables.h \ - s390x_tables.h x86_64_tables.h + s390x_tables.h x86_64_tables.h uringop_tables.h if USE_ARM BUILT_SOURCES += arm_tables.h endif @@ -58,7 +58,7 @@ noinst_PROGRAMS = gen_actiontabs_h gen_errtabs_h gen_fieldtabs_h \ gen_flagtabs_h gen_fstypetabs_h gen_ftypetabs_h gen_i386_tables_h \ gen_machinetabs_h gen_msg_typetabs_h \ gen_optabs_h gen_ppc_tables_h gen_s390_tables_h \ - gen_s390x_tables_h gen_x86_64_tables_h + gen_s390x_tables_h gen_x86_64_tables_h gen_uringop_tables_h if USE_ARM noinst_PROGRAMS += gen_arm_tables_h endif @@ -266,6 +266,19 @@ gen_s390x_tables_h$(BUILD_EXEEXT): LDFLAGS=$(LDFLAGS_FOR_BUILD) s390x_tables.h: gen_s390x_tables_h Makefile ./gen_s390x_tables_h --lowercase --i2s --s2i s390x_syscall > $@ +gen_uringop_tables_h_SOURCES = gen_tables.c gen_tables.h uringop_table.h +gen_uringop_tables_h_CFLAGS = '-DTABLE_H="uringop_table.h"' +$(gen_uringop_tables_h_OBJECTS): CC=$(CC_FOR_BUILD) +$(gen_uringop_tables_h_OBJECTS): CFLAGS=$(CFLAGS_FOR_BUILD) +$(gen_uringop_tables_h_OBJECTS): CPPFLAGS=$(CPPFLAGS_FOR_BUILD) +$(gen_uringop_tables_h_OBJECTS): LDFLAGS=$(LDFLAGS_FOR_BUILD) +gen_uringop_tables_h$(BUILD_EXEEXT): CC=$(CC_FOR_BUILD) +gen_uringop_tables_h$(BUILD_EXEEXT): CFLAGS=$(CFLAGS_FOR_BUILD) +gen_uringop_tables_h$(BUILD_EXEEXT): CPPFLAGS=$(CPPFLAGS_FOR_BUILD) +gen_uringop_tables_h$(BUILD_EXEEXT): LDFLAGS=$(LDFLAGS_FOR_BUILD) +uringop_tables.h: gen_uringop_tables_h Makefile + ./gen_uringop_tables_h --lowercase --i2s --s2i uringop > $@ + gen_x86_64_tables_h_SOURCES = gen_tables.c gen_tables.h x86_64_table.h gen_x86_64_tables_h_CFLAGS = '-DTABLE_H="x86_64_table.h"' $(gen_x86_64_tables_h_OBJECTS): CC=$(CC_FOR_BUILD) diff --git a/lib/lookup_table.c b/lib/lookup_table.c index ca619fba930d..d895b1ffe530 100644 --- a/lib/lookup_table.c +++ b/lib/lookup_table.c @@ -46,6 +46,7 @@ #include "s390_tables.h" #include "s390x_tables.h" #include "x86_64_tables.h" +#include "uringop_tables.h" #include "errtabs.h" #include "fstypetabs.h" #include "ftypetabs.h" @@ -147,7 +148,7 @@ int audit_name_to_uringop(const char *uringop) int res = -1, found = 0; #ifndef NO_TABLES - //found = uringop_s2i(uringop, &res); + found = uringop_s2i(uringop, &res); #endif if (found) return res; @@ -187,7 +188,7 @@ const char *audit_syscall_to_name(int sc, int machine) const char *audit_uringop_to_name(int uringop) { #ifndef NO_TABLES - //return uringop_i2s(uringop); + return uringop_i2s(uringop); #endif return NULL; } diff --git a/lib/test/lookup_test.c b/lib/test/lookup_test.c index 03f40aaf0899..f58d9dde65dd 100644 --- a/lib/test/lookup_test.c +++ b/lib/test/lookup_test.c @@ -234,6 +234,22 @@ test_x86_64_table(void) #undef S2I } +static void +test_uringop_table(void) +{ + static const struct entry t[] = { +#include "../uringop_table.h" + }; + + printf("Testing uringop_table...\n"); +#define I2S(I) audit_uringop_to_name((I)) +#define S2I(S) audit_name_to_uringop((S)) + TEST_I2S(0); + TEST_S2I(-1); +#undef I2S +#undef S2I +} + static void test_actiontab(void) { @@ -395,6 +411,7 @@ main(void) test_s390_table(); test_s390x_table(); test_x86_64_table(); + test_uringop_table(); test_actiontab(); test_errtab(); test_fieldtab(); diff --git a/lib/uringop_table.h b/lib/uringop_table.h new file mode 100644 index 000000000000..241828efc654 --- /dev/null +++ b/lib/uringop_table.h @@ -0,0 +1,62 @@ +/* uringop_table.h -- + * Copyright 2005-21 Red Hat Inc. + * All Rights Reserved. + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + * Authors: + * Richard Guy Briggs <rgb@xxxxxxxxxx> + */ + +/* from /usr/include/linux/io_uring.h */ + +_S(0, "nop") +_S(1, "readv") +_S(2, "writev") +_S(3, "fsync") +_S(4, "read_fixed") +_S(5, "write_fixed") +_S(6, "poll_add") +_S(7, "poll_remove") +_S(8, "sync_file_range") +_S(9, "sendmsg") +_S(10, "recvmsg") +_S(11, "timeout") +_S(12, "timeout_remove") +_S(13, "accept") +_S(14, "async_cancel") +_S(15, "link_timeout") +_S(16, "connect") +_S(17, "fallocate") +_S(18, "openat") +_S(19, "close") +_S(20, "files_update") +_S(21, "statx") +_S(22, "read") +_S(23, "write") +_S(24, "fadvise") +_S(25, "madvise") +_S(26, "send") +_S(27, "recv") +_S(28, "openat2") +_S(29, "epoll_ctl") +_S(30, "splice") +_S(31, "provide_bufers") +_S(32, "remove_bufers") +_S(33, "tee") +_S(34, "shutdown") +_S(35, "renameat") +_S(36, "unlinkat") + -- 2.27.0