Re: [2.6.16-rc6-m1 PATCH] Connector: Filesystem Events Connector

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Yi Yang <[email protected]> wrote:
>
> This patch implements a new connector, Filesystem Event Connector,
>  the user can monitor filesystem activities via it, currently, it
>  can monitor access, attribute change, open, create, modify, delete,
>  move and close of any file or directory.
> 
> Every filesystem event will include tgid, uid and gid of the process
>  which triggered this event, process name, file or directory name 
> operated by it.

Why does Linux need this feature?

It seems quite duplicative of the fsnotify stuff.

>  	/* both times implies a utime(s) call */
>  	if ((ia_valid & (ATTR_ATIME | ATTR_MTIME)) == (ATTR_ATIME | ATTR_MTIME))
>  	{
>  		in_mask |= IN_ATTRIB;
>  		dn_mask |= DN_ATTRIB;
> +		fsevent_mask |= FSEVENT_MODIFY_ATTRIB;
>  	} else if (ia_valid & ATTR_ATIME) {
>  		in_mask |= IN_ACCESS;
>  		dn_mask |= DN_ACCESS;
> +		fsevent_mask |= FSEVENT_ACCESS;
>  	} else if (ia_valid & ATTR_MTIME) {
>  		in_mask |= IN_MODIFY;
>  		dn_mask |= DN_MODIFY;
> +		fsevent_mask |= FSEVENT_MODIFY;
>  	}
>  	if (ia_valid & ATTR_MODE) {
>  		in_mask |= IN_ATTRIB;
>  		dn_mask |= DN_ATTRIB;
> +		fsevent_mask |= FSEVENT_MODIFY_ATTRIB;
>  	}
>  
>  	if (dn_mask)
> @@ -238,6 +279,11 @@ static inline void fsnotify_change(struc
>  		inotify_dentry_parent_queue_event(dentry, in_mask, 0,
>  						  dentry->d_name.name);
>  	}
> +	if (fsevent_mask) {
> +		if (S_ISDIR(inode->i_mode))
> +			fsevent_mask |= FSEVENT_ISDIR;
> +		raise_fsevent(dentry, fsevent_mask);
> +	}
>  }

hmm, I wonder if the compiler is smart enough to recognise that
fsevent_mask isn't used and to eliminate all this new code when
CONFIG_FS_EVENTS=n

> +extern void raise_fsevent_move(struct inode * olddir, const char * oldname, struct inode * newdir, const char * newname, u32 mask);

Try to keep code looking nice in an 80-col display please.


> +int __raise_fsevent(const char * oldname, const char * newname, u32 mask)
> +{
> +	struct cn_msg *msg;
> +	struct fsevent *event;
> +	__u8 * buffer;
> +	int namelen = 0;
> +	static unsigned long last;
> +	static int fsevent_sum = 0;
> +
> +	if (atomic_read(&cn_fs_event_listeners) < 1)
> +		return 0;
> +
> +	spin_lock(&fsevent_ratelimit_lock);
> 

yipes.  We just went through considerable pain fixing performance problems
with inotify, and this patch brings them back, only much much worse.

See ftp://ftp.kernel.org/pub/linux/kernel/people/akpm/patches/2.6/2.6.16-rc6/2.6.16-rc6-mm1/broken-out/inotify-lock-avoidance-with-parent-watch-status-in-dentry.patch
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux