[LTP] [PATCH 2/6] fanotify: Provide fanotify_mark_supported_on_fs()

Amir Goldstein amir73il@gmail.com
Wed Nov 29 15:47:56 CET 2023


On Wed, Nov 29, 2023 at 1:54 PM Jan Kara <jack@suse.cz> wrote:
>
> Provide helper checking whether a mark is supported on a filesystem
> since some marks need not be available on all filesystems (e.g. btrfs
> subvolumes). Also convert REQUIRE_MARK_TYPE_SUPPORTED_BY_KERNEL() and
> its only user to use this new function.
>
> Signed-off-by: Jan Kara <jack@suse.cz>
> ---
>  testcases/kernel/syscalls/fanotify/fanotify.h   | 11 ++++++++---
>  testcases/kernel/syscalls/fanotify/fanotify23.c |  2 +-
>  2 files changed, 9 insertions(+), 4 deletions(-)
>
> diff --git a/testcases/kernel/syscalls/fanotify/fanotify.h b/testcases/kernel/syscalls/fanotify/fanotify.h
> index ee74c2fffbd5..f28da1a5ee55 100644
> --- a/testcases/kernel/syscalls/fanotify/fanotify.h
> +++ b/testcases/kernel/syscalls/fanotify/fanotify.h
> @@ -226,6 +226,11 @@ static inline int fanotify_init_flags_supported_by_kernel(unsigned int flags)
>         return fanotify_init_flags_supported_on_fs(flags, NULL);
>  }
>
> +static inline int fanotify_mark_supported_on_fs(uint64_t flag, const char *fname)
> +{
> +       return fanotify_flags_supported_on_fs(FAN_CLASS_CONTENT, flag, FAN_ACCESS, fname);

Why not FAN_CLASS_NOTIF?

> +}
> +
>  #define TST_FANOTIFY_INIT_KNOWN_FLAGS                                      \
>         (FAN_REPORT_DFID_NAME_TARGET | FAN_REPORT_TID | FAN_REPORT_PIDFD | \
>         FAN_CLASS_NOTIF | FAN_CLASS_CONTENT | FAN_CLASS_PRE_CONTENT)
> @@ -333,9 +338,9 @@ static inline int fanotify_handle_supported_by_kernel(int flag)
>         return 0;
>  }
>
> -#define REQUIRE_MARK_TYPE_SUPPORTED_BY_KERNEL(mark_type) \
> +#define REQUIRE_MARK_TYPE_SUPPORTED_ON_FS(mark_type, fname) \
>         fanotify_flags_err_msg(#mark_type, __FILE__, __LINE__, tst_brk_, \
> -               fanotify_mark_supported_by_kernel(mark_type))
> +               fanotify_mark_supported_on_fs(mark_type, fname))
>
>  #define REQUIRE_HANDLE_TYPE_SUPPORTED_BY_KERNEL(handle_type) \
>         fanotify_flags_err_msg(#handle_type, __FILE__, __LINE__, tst_brk_, \
> @@ -343,7 +348,7 @@ static inline int fanotify_handle_supported_by_kernel(int flag)
>
>  #define REQUIRE_FANOTIFY_EVENTS_SUPPORTED_ON_FS(init_flags, mark_type, mask, fname) do { \
>         if (mark_type)                                                  \
> -               REQUIRE_MARK_TYPE_SUPPORTED_BY_KERNEL(mark_type);       \
> +               REQUIRE_MARK_TYPE_SUPPORTED_ON_FS(mark_type, fname);    \
>         if (init_flags)                                                 \
>                 REQUIRE_FANOTIFY_INIT_FLAGS_SUPPORTED_ON_FS(init_flags, fname); \
>         fanotify_flags_err_msg(#mask, __FILE__, __LINE__, tst_brk_, \
> diff --git a/testcases/kernel/syscalls/fanotify/fanotify23.c b/testcases/kernel/syscalls/fanotify/fanotify23.c
> index fb812c51e34e..5a03503e952a 100644
> --- a/testcases/kernel/syscalls/fanotify/fanotify23.c
> +++ b/testcases/kernel/syscalls/fanotify/fanotify23.c
> @@ -230,7 +230,7 @@ static void setup(void)
>  {
>         SAFE_TOUCH(TEST_FILE, 0666, NULL);
>
> -       REQUIRE_MARK_TYPE_SUPPORTED_BY_KERNEL(FAN_MARK_EVICTABLE);
> +       REQUIRE_MARK_TYPE_SUPPORTED_ON_FS(FAN_MARK_EVICTABLE, ".");
>         REQUIRE_FANOTIFY_EVENTS_SUPPORTED_ON_FS(FAN_CLASS_NOTIF|FAN_REPORT_FID,
>                                                 FAN_MARK_FILESYSTEM,
>                                                 FAN_ATTRIB, ".");
> --
> 2.35.3
>


More information about the ltp mailing list