[LTP] [PATCH 1/3] fanotify24: remove redundant event_count field

Jan Kara jack@suse.cz
Mon Mar 24 14:23:20 CET 2025


On Wed 19-03-25 20:27:40, Amir Goldstein wrote:
> treat the event-set as a null terminated array.
> 
> Signed-off-by: Amir Goldstein <amir73il@gmail.com>

Looks good. Feel free to add:

Reviewed-by: Jan Kara <jack@suse.cz>

								Honza

> ---
>  .../kernel/syscalls/fanotify/fanotify24.c     | 31 +++++++++----------
>  1 file changed, 15 insertions(+), 16 deletions(-)
> 
> diff --git a/testcases/kernel/syscalls/fanotify/fanotify24.c b/testcases/kernel/syscalls/fanotify/fanotify24.c
> index 8a448ea50..539f74137 100644
> --- a/testcases/kernel/syscalls/fanotify/fanotify24.c
> +++ b/testcases/kernel/syscalls/fanotify/fanotify24.c
> @@ -60,13 +60,12 @@ static struct tcase {
>  	const char *tname;
>  	struct fanotify_mark_type mark;
>  	unsigned long long mask;
> -	int event_count;
>  	struct event event_set[EVENT_SET_MAX];
>  } tcases[] = {
>  	{
>  		"inode mark, FAN_OPEN_PERM | FAN_PRE_ACCESS events",
>  		INIT_FANOTIFY_MARK_TYPE(INODE),
> -		FAN_OPEN_PERM | FAN_PRE_ACCESS, 4,
> +		FAN_OPEN_PERM | FAN_PRE_ACCESS,
>  		{
>  			{FAN_OPEN_PERM, FAN_ALLOW},
>  			{FAN_PRE_ACCESS, FAN_DENY},
> @@ -77,7 +76,7 @@ static struct tcase {
>  	{
>  		"inode mark, FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM events",
>  		INIT_FANOTIFY_MARK_TYPE(INODE),
> -		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM, 3,
> +		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM,
>  		{
>  			{FAN_PRE_ACCESS, FAN_DENY},
>  			{FAN_PRE_ACCESS, FAN_DENY_ERRNO(EIO)},
> @@ -87,7 +86,7 @@ static struct tcase {
>  	{
>  		"mount mark, FAN_OPEN_PERM | FAN_PRE_ACCESS events",
>  		INIT_FANOTIFY_MARK_TYPE(MOUNT),
> -		FAN_OPEN_PERM | FAN_PRE_ACCESS, 4,
> +		FAN_OPEN_PERM | FAN_PRE_ACCESS,
>  		{
>  			{FAN_OPEN_PERM, FAN_ALLOW},
>  			{FAN_PRE_ACCESS, FAN_DENY},
> @@ -98,7 +97,7 @@ static struct tcase {
>  	{
>  		"mount mark, FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM events",
>  		INIT_FANOTIFY_MARK_TYPE(MOUNT),
> -		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM, 3,
> +		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM,
>  		{
>  			{FAN_PRE_ACCESS, FAN_DENY},
>  			{FAN_PRE_ACCESS, FAN_DENY_ERRNO(EIO)},
> @@ -108,7 +107,7 @@ static struct tcase {
>  	{
>  		"filesystem mark, FAN_OPEN_PERM | FAN_PRE_ACCESS events",
>  		INIT_FANOTIFY_MARK_TYPE(FILESYSTEM),
> -		FAN_OPEN_PERM | FAN_PRE_ACCESS, 4,
> +		FAN_OPEN_PERM | FAN_PRE_ACCESS,
>  		{
>  			{FAN_OPEN_PERM, FAN_ALLOW},
>  			{FAN_PRE_ACCESS, FAN_DENY},
> @@ -119,7 +118,7 @@ static struct tcase {
>  	{
>  		"filesystem mark, FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM events",
>  		INIT_FANOTIFY_MARK_TYPE(FILESYSTEM),
> -		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM, 3,
> +		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM,
>  		{
>  			{FAN_PRE_ACCESS, FAN_DENY},
>  			{FAN_PRE_ACCESS, FAN_DENY_ERRNO(EIO)},
> @@ -129,7 +128,7 @@ static struct tcase {
>  	{
>  		"parent watching children, FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM events",
>  		INIT_FANOTIFY_MARK_TYPE(PARENT),
> -		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM | FAN_EVENT_ON_CHILD, 3,
> +		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM | FAN_EVENT_ON_CHILD,
>  		{
>  			{FAN_PRE_ACCESS, FAN_DENY},
>  			{FAN_PRE_ACCESS, FAN_DENY},
> @@ -139,14 +138,14 @@ static struct tcase {
>  	{
>  		"parent not watching children, FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM events",
>  		INIT_FANOTIFY_MARK_TYPE(PARENT),
> -		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM, 0,
> +		FAN_PRE_ACCESS | FAN_OPEN_EXEC_PERM,
>  		{
>  		}
>  	},
>  	{
>  		"inode mark, FAN_PRE_ACCESS event allowed",
>  		INIT_FANOTIFY_MARK_TYPE(INODE),
> -		FAN_PRE_ACCESS, 1,
> +		FAN_PRE_ACCESS,
>  		{
>  			/* This allows multiple FAN_PRE_ACCESS events */
>  			{FAN_PRE_ACCESS, FAN_ALLOW},
> @@ -225,7 +224,7 @@ static void generate_events(struct tcase *tc)
>  	 */
>  	if (!exp_errno) {
>  		fd = SAFE_OPEN(FILE_EXEC_PATH, O_RDWR);
> -		if (!tc->event_count)
> +		if (!tc->event_set[0].mask)
>  			exp_errno = ETXTBSY;
>  	}
>  
> @@ -335,10 +334,10 @@ static void test_fanotify(unsigned int n)
>  	/*
>  	 * Process events
>  	 *
> -	 * tc->count + 1 is to let read() wait for child process to exit
> -	 * and to accomodate for extra access events
> +	 * even if we do not expect another event, let read() wait for child
> +	 * process to exit and accomodate for multiple access events
>  	 */
> -	while (test_num < tc->event_count + 1 && fd_notify != -1) {
> +	while (test_num < EVENT_SET_MAX && fd_notify != -1) {
>  		struct fanotify_event_metadata *event;
>  
>  		if (i == len) {
> @@ -363,7 +362,7 @@ static void test_fanotify(unsigned int n)
>  		 * generate an unknown number of access permission events if they
>  		 * are allowed.
>  		 */
> -		if (test_num > 0 && test_num == tc->event_count &&
> +		if (test_num > 0 && !event_set[test_num].mask &&
>  		    event_set[test_num-1].response == FAN_ALLOW)
>  			test_num--;
>  
> @@ -418,7 +417,7 @@ static void test_fanotify(unsigned int n)
>  		test_num++;
>  	}
>  
> -	for (; test_num < tc->event_count; test_num++) {
> +	for (; event_set[test_num].mask && test_num < EVENT_SET_MAX; test_num++) {
>  		tst_res(TFAIL, "didn't get event: mask=%llx",
>  			event_set[test_num].mask);
>  
> -- 
> 2.34.1
> 
-- 
Jan Kara <jack@suse.com>
SUSE Labs, CR


More information about the ltp mailing list