mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-04-04 21:44:28 +00:00
fsnotify: switch send_to_group() and ->handle_event to const struct qstr *
note that conditions surrounding accesses to dname in audit_watch_handle_event() and audit_mark_handle_event() guarantee that dname won't have been NULL. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
25b229dff4
commit
e43e9c339a
9 changed files with 15 additions and 15 deletions
|
@ -81,7 +81,7 @@ static void dnotify_recalc_inode_mask(struct fsnotify_mark *fsn_mark)
|
||||||
static int dnotify_handle_event(struct fsnotify_group *group,
|
static int dnotify_handle_event(struct fsnotify_group *group,
|
||||||
struct inode *inode,
|
struct inode *inode,
|
||||||
u32 mask, const void *data, int data_type,
|
u32 mask, const void *data, int data_type,
|
||||||
const unsigned char *file_name, u32 cookie,
|
const struct qstr *file_name, u32 cookie,
|
||||||
struct fsnotify_iter_info *iter_info)
|
struct fsnotify_iter_info *iter_info)
|
||||||
{
|
{
|
||||||
struct fsnotify_mark *inode_mark = fsnotify_iter_inode_mark(iter_info);
|
struct fsnotify_mark *inode_mark = fsnotify_iter_inode_mark(iter_info);
|
||||||
|
|
|
@ -361,7 +361,7 @@ static __kernel_fsid_t fanotify_get_fsid(struct fsnotify_iter_info *iter_info)
|
||||||
static int fanotify_handle_event(struct fsnotify_group *group,
|
static int fanotify_handle_event(struct fsnotify_group *group,
|
||||||
struct inode *inode,
|
struct inode *inode,
|
||||||
u32 mask, const void *data, int data_type,
|
u32 mask, const void *data, int data_type,
|
||||||
const unsigned char *file_name, u32 cookie,
|
const struct qstr *file_name, u32 cookie,
|
||||||
struct fsnotify_iter_info *iter_info)
|
struct fsnotify_iter_info *iter_info)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
|
@ -195,7 +195,7 @@ EXPORT_SYMBOL_GPL(__fsnotify_parent);
|
||||||
static int send_to_group(struct inode *to_tell,
|
static int send_to_group(struct inode *to_tell,
|
||||||
__u32 mask, const void *data,
|
__u32 mask, const void *data,
|
||||||
int data_is, u32 cookie,
|
int data_is, u32 cookie,
|
||||||
const unsigned char *file_name,
|
const struct qstr *file_name,
|
||||||
struct fsnotify_iter_info *iter_info)
|
struct fsnotify_iter_info *iter_info)
|
||||||
{
|
{
|
||||||
struct fsnotify_group *group = NULL;
|
struct fsnotify_group *group = NULL;
|
||||||
|
@ -379,7 +379,7 @@ int fsnotify(struct inode *to_tell, __u32 mask, const void *data, int data_is,
|
||||||
*/
|
*/
|
||||||
while (fsnotify_iter_select_report_types(&iter_info)) {
|
while (fsnotify_iter_select_report_types(&iter_info)) {
|
||||||
ret = send_to_group(to_tell, mask, data, data_is, cookie,
|
ret = send_to_group(to_tell, mask, data, data_is, cookie,
|
||||||
file_name->name, &iter_info);
|
file_name, &iter_info);
|
||||||
|
|
||||||
if (ret && (mask & ALL_FSNOTIFY_PERM_EVENTS))
|
if (ret && (mask & ALL_FSNOTIFY_PERM_EVENTS))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
|
@ -27,7 +27,7 @@ extern void inotify_ignored_and_remove_idr(struct fsnotify_mark *fsn_mark,
|
||||||
extern int inotify_handle_event(struct fsnotify_group *group,
|
extern int inotify_handle_event(struct fsnotify_group *group,
|
||||||
struct inode *inode,
|
struct inode *inode,
|
||||||
u32 mask, const void *data, int data_type,
|
u32 mask, const void *data, int data_type,
|
||||||
const unsigned char *file_name, u32 cookie,
|
const struct qstr *file_name, u32 cookie,
|
||||||
struct fsnotify_iter_info *iter_info);
|
struct fsnotify_iter_info *iter_info);
|
||||||
|
|
||||||
extern const struct fsnotify_ops inotify_fsnotify_ops;
|
extern const struct fsnotify_ops inotify_fsnotify_ops;
|
||||||
|
|
|
@ -67,7 +67,7 @@ static int inotify_merge(struct list_head *list,
|
||||||
int inotify_handle_event(struct fsnotify_group *group,
|
int inotify_handle_event(struct fsnotify_group *group,
|
||||||
struct inode *inode,
|
struct inode *inode,
|
||||||
u32 mask, const void *data, int data_type,
|
u32 mask, const void *data, int data_type,
|
||||||
const unsigned char *file_name, u32 cookie,
|
const struct qstr *file_name, u32 cookie,
|
||||||
struct fsnotify_iter_info *iter_info)
|
struct fsnotify_iter_info *iter_info)
|
||||||
{
|
{
|
||||||
struct fsnotify_mark *inode_mark = fsnotify_iter_inode_mark(iter_info);
|
struct fsnotify_mark *inode_mark = fsnotify_iter_inode_mark(iter_info);
|
||||||
|
@ -89,7 +89,7 @@ int inotify_handle_event(struct fsnotify_group *group,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (file_name) {
|
if (file_name) {
|
||||||
len = strlen(file_name);
|
len = strlen(file_name->name);
|
||||||
alloc_len += len + 1;
|
alloc_len += len + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -129,7 +129,7 @@ int inotify_handle_event(struct fsnotify_group *group,
|
||||||
event->sync_cookie = cookie;
|
event->sync_cookie = cookie;
|
||||||
event->name_len = len;
|
event->name_len = len;
|
||||||
if (len)
|
if (len)
|
||||||
strcpy(event->name, file_name);
|
strcpy(event->name, file_name->name);
|
||||||
|
|
||||||
ret = fsnotify_add_event(group, fsn_event, inotify_merge);
|
ret = fsnotify_add_event(group, fsn_event, inotify_merge);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
|
|
@ -117,7 +117,7 @@ struct fsnotify_ops {
|
||||||
int (*handle_event)(struct fsnotify_group *group,
|
int (*handle_event)(struct fsnotify_group *group,
|
||||||
struct inode *inode,
|
struct inode *inode,
|
||||||
u32 mask, const void *data, int data_type,
|
u32 mask, const void *data, int data_type,
|
||||||
const unsigned char *file_name, u32 cookie,
|
const struct qstr *file_name, u32 cookie,
|
||||||
struct fsnotify_iter_info *iter_info);
|
struct fsnotify_iter_info *iter_info);
|
||||||
void (*free_group_priv)(struct fsnotify_group *group);
|
void (*free_group_priv)(struct fsnotify_group *group);
|
||||||
void (*freeing_mark)(struct fsnotify_mark *mark, struct fsnotify_group *group);
|
void (*freeing_mark)(struct fsnotify_mark *mark, struct fsnotify_group *group);
|
||||||
|
|
|
@ -164,7 +164,7 @@ static void audit_autoremove_mark_rule(struct audit_fsnotify_mark *audit_mark)
|
||||||
static int audit_mark_handle_event(struct fsnotify_group *group,
|
static int audit_mark_handle_event(struct fsnotify_group *group,
|
||||||
struct inode *to_tell,
|
struct inode *to_tell,
|
||||||
u32 mask, const void *data, int data_type,
|
u32 mask, const void *data, int data_type,
|
||||||
const unsigned char *dname, u32 cookie,
|
const struct qstr *dname, u32 cookie,
|
||||||
struct fsnotify_iter_info *iter_info)
|
struct fsnotify_iter_info *iter_info)
|
||||||
{
|
{
|
||||||
struct fsnotify_mark *inode_mark = fsnotify_iter_inode_mark(iter_info);
|
struct fsnotify_mark *inode_mark = fsnotify_iter_inode_mark(iter_info);
|
||||||
|
@ -188,7 +188,7 @@ static int audit_mark_handle_event(struct fsnotify_group *group,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mask & (FS_CREATE|FS_MOVED_TO|FS_DELETE|FS_MOVED_FROM)) {
|
if (mask & (FS_CREATE|FS_MOVED_TO|FS_DELETE|FS_MOVED_FROM)) {
|
||||||
if (audit_compare_dname_path(dname, audit_mark->path, AUDIT_NAME_FULL))
|
if (audit_compare_dname_path(dname->name, audit_mark->path, AUDIT_NAME_FULL))
|
||||||
return 0;
|
return 0;
|
||||||
audit_update_mark(audit_mark, inode);
|
audit_update_mark(audit_mark, inode);
|
||||||
} else if (mask & (FS_DELETE_SELF|FS_UNMOUNT|FS_MOVE_SELF))
|
} else if (mask & (FS_DELETE_SELF|FS_UNMOUNT|FS_MOVE_SELF))
|
||||||
|
|
|
@ -1040,7 +1040,7 @@ static void evict_chunk(struct audit_chunk *chunk)
|
||||||
static int audit_tree_handle_event(struct fsnotify_group *group,
|
static int audit_tree_handle_event(struct fsnotify_group *group,
|
||||||
struct inode *to_tell,
|
struct inode *to_tell,
|
||||||
u32 mask, const void *data, int data_type,
|
u32 mask, const void *data, int data_type,
|
||||||
const unsigned char *file_name, u32 cookie,
|
const struct qstr *file_name, u32 cookie,
|
||||||
struct fsnotify_iter_info *iter_info)
|
struct fsnotify_iter_info *iter_info)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -482,7 +482,7 @@ void audit_remove_watch_rule(struct audit_krule *krule)
|
||||||
static int audit_watch_handle_event(struct fsnotify_group *group,
|
static int audit_watch_handle_event(struct fsnotify_group *group,
|
||||||
struct inode *to_tell,
|
struct inode *to_tell,
|
||||||
u32 mask, const void *data, int data_type,
|
u32 mask, const void *data, int data_type,
|
||||||
const unsigned char *dname, u32 cookie,
|
const struct qstr *dname, u32 cookie,
|
||||||
struct fsnotify_iter_info *iter_info)
|
struct fsnotify_iter_info *iter_info)
|
||||||
{
|
{
|
||||||
struct fsnotify_mark *inode_mark = fsnotify_iter_inode_mark(iter_info);
|
struct fsnotify_mark *inode_mark = fsnotify_iter_inode_mark(iter_info);
|
||||||
|
@ -507,9 +507,9 @@ static int audit_watch_handle_event(struct fsnotify_group *group,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mask & (FS_CREATE|FS_MOVED_TO) && inode)
|
if (mask & (FS_CREATE|FS_MOVED_TO) && inode)
|
||||||
audit_update_watch(parent, dname, inode->i_sb->s_dev, inode->i_ino, 0);
|
audit_update_watch(parent, dname->name, inode->i_sb->s_dev, inode->i_ino, 0);
|
||||||
else if (mask & (FS_DELETE|FS_MOVED_FROM))
|
else if (mask & (FS_DELETE|FS_MOVED_FROM))
|
||||||
audit_update_watch(parent, dname, AUDIT_DEV_UNSET, AUDIT_INO_UNSET, 1);
|
audit_update_watch(parent, dname->name, AUDIT_DEV_UNSET, AUDIT_INO_UNSET, 1);
|
||||||
else if (mask & (FS_DELETE_SELF|FS_UNMOUNT|FS_MOVE_SELF))
|
else if (mask & (FS_DELETE_SELF|FS_UNMOUNT|FS_MOVE_SELF))
|
||||||
audit_remove_parent_watches(parent);
|
audit_remove_parent_watches(parent);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue