diff options
author | Eric Paris <eparis@redhat.com> | 2009-12-17 21:24:24 -0500 |
---|---|---|
committer | Eric Paris <eparis@redhat.com> | 2010-07-28 09:58:54 -0400 |
commit | 000285deb99a5e0636fdd3c6a2483a5d039ee2c2 (patch) | |
tree | 45b13f2253265703a540bdd99685f4f56ac8e21b /fs/notify | |
parent | 841bdc10f573aa010dd5818d35a5690b7d9f73ce (diff) |
inotify: rename mark_entry to just mark
rename anything in inotify that deals with mark_entry to just be mark. It
makes a lot more sense.
Signed-off-by: Eric Paris <eparis@redhat.com>
Diffstat (limited to 'fs/notify')
-rw-r--r-- | fs/notify/inotify/inotify.h | 7 | ||||
-rw-r--r-- | fs/notify/inotify/inotify_fsnotify.c | 48 | ||||
-rw-r--r-- | fs/notify/inotify/inotify_user.c | 192 |
3 files changed, 123 insertions, 124 deletions
diff --git a/fs/notify/inotify/inotify.h b/fs/notify/inotify/inotify.h index 07be6df2428f..b6642e4de4bf 100644 --- a/fs/notify/inotify/inotify.h +++ b/fs/notify/inotify/inotify.h | |||
@@ -9,13 +9,12 @@ struct inotify_event_private_data { | |||
9 | int wd; | 9 | int wd; |
10 | }; | 10 | }; |
11 | 11 | ||
12 | struct inotify_inode_mark_entry { | 12 | struct inotify_inode_mark { |
13 | /* fsnotify_mark MUST be the first thing */ | 13 | struct fsnotify_mark fsn_mark; |
14 | struct fsnotify_mark fsn_entry; | ||
15 | int wd; | 14 | int wd; |
16 | }; | 15 | }; |
17 | 16 | ||
18 | extern void inotify_ignored_and_remove_idr(struct fsnotify_mark *entry, | 17 | extern void inotify_ignored_and_remove_idr(struct fsnotify_mark *fsn_mark, |
19 | struct fsnotify_group *group); | 18 | struct fsnotify_group *group); |
20 | extern void inotify_free_event_priv(struct fsnotify_event_private_data *event_priv); | 19 | extern void inotify_free_event_priv(struct fsnotify_event_private_data *event_priv); |
21 | 20 | ||
diff --git a/fs/notify/inotify/inotify_fsnotify.c b/fs/notify/inotify/inotify_fsnotify.c index f8a2a6eda133..12dc72be992e 100644 --- a/fs/notify/inotify/inotify_fsnotify.c +++ b/fs/notify/inotify/inotify_fsnotify.c | |||
@@ -88,8 +88,8 @@ static int inotify_merge(struct list_head *list, struct fsnotify_event *event) | |||
88 | 88 | ||
89 | static int inotify_handle_event(struct fsnotify_group *group, struct fsnotify_event *event) | 89 | static int inotify_handle_event(struct fsnotify_group *group, struct fsnotify_event *event) |
90 | { | 90 | { |
91 | struct fsnotify_mark *entry; | 91 | struct fsnotify_mark *fsn_mark; |
92 | struct inotify_inode_mark_entry *ientry; | 92 | struct inotify_inode_mark *i_mark; |
93 | struct inode *to_tell; | 93 | struct inode *to_tell; |
94 | struct inotify_event_private_data *event_priv; | 94 | struct inotify_event_private_data *event_priv; |
95 | struct fsnotify_event_private_data *fsn_event_priv; | 95 | struct fsnotify_event_private_data *fsn_event_priv; |
@@ -98,14 +98,14 @@ static int inotify_handle_event(struct fsnotify_group *group, struct fsnotify_ev | |||
98 | to_tell = event->to_tell; | 98 | to_tell = event->to_tell; |
99 | 99 | ||
100 | spin_lock(&to_tell->i_lock); | 100 | spin_lock(&to_tell->i_lock); |
101 | entry = fsnotify_find_mark(group, to_tell); | 101 | fsn_mark = fsnotify_find_mark(group, to_tell); |
102 | spin_unlock(&to_tell->i_lock); | 102 | spin_unlock(&to_tell->i_lock); |
103 | /* race with watch removal? We already passes should_send */ | 103 | /* race with watch removal? We already passes should_send */ |
104 | if (unlikely(!entry)) | 104 | if (unlikely(!fsn_mark)) |
105 | return 0; | 105 | return 0; |
106 | ientry = container_of(entry, struct inotify_inode_mark_entry, | 106 | i_mark = container_of(fsn_mark, struct inotify_inode_mark, |
107 | fsn_entry); | 107 | fsn_mark); |
108 | wd = ientry->wd; | 108 | wd = i_mark->wd; |
109 | 109 | ||
110 | event_priv = kmem_cache_alloc(event_priv_cachep, GFP_KERNEL); | 110 | event_priv = kmem_cache_alloc(event_priv_cachep, GFP_KERNEL); |
111 | if (unlikely(!event_priv)) | 111 | if (unlikely(!event_priv)) |
@@ -127,37 +127,37 @@ static int inotify_handle_event(struct fsnotify_group *group, struct fsnotify_ev | |||
127 | } | 127 | } |
128 | 128 | ||
129 | /* | 129 | /* |
130 | * If we hold the entry until after the event is on the queue | 130 | * If we hold the fsn_mark until after the event is on the queue |
131 | * IN_IGNORED won't be able to pass this event in the queue | 131 | * IN_IGNORED won't be able to pass this event in the queue |
132 | */ | 132 | */ |
133 | fsnotify_put_mark(entry); | 133 | fsnotify_put_mark(fsn_mark); |
134 | 134 | ||
135 | return ret; | 135 | return ret; |
136 | } | 136 | } |
137 | 137 | ||
138 | static void inotify_freeing_mark(struct fsnotify_mark *entry, struct fsnotify_group *group) | 138 | static void inotify_freeing_mark(struct fsnotify_mark *fsn_mark, struct fsnotify_group *group) |
139 | { | 139 | { |
140 | inotify_ignored_and_remove_idr(entry, group); | 140 | inotify_ignored_and_remove_idr(fsn_mark, group); |
141 | } | 141 | } |
142 | 142 | ||
143 | static bool inotify_should_send_event(struct fsnotify_group *group, struct inode *inode, | 143 | static bool inotify_should_send_event(struct fsnotify_group *group, struct inode *inode, |
144 | struct vfsmount *mnt, __u32 mask, void *data, | 144 | struct vfsmount *mnt, __u32 mask, void *data, |
145 | int data_type) | 145 | int data_type) |
146 | { | 146 | { |
147 | struct fsnotify_mark *entry; | 147 | struct fsnotify_mark *fsn_mark; |
148 | bool send; | 148 | bool send; |
149 | 149 | ||
150 | spin_lock(&inode->i_lock); | 150 | spin_lock(&inode->i_lock); |
151 | entry = fsnotify_find_mark(group, inode); | 151 | fsn_mark = fsnotify_find_mark(group, inode); |
152 | spin_unlock(&inode->i_lock); | 152 | spin_unlock(&inode->i_lock); |
153 | if (!entry) | 153 | if (!fsn_mark) |
154 | return false; | 154 | return false; |
155 | 155 | ||
156 | mask = (mask & ~FS_EVENT_ON_CHILD); | 156 | mask = (mask & ~FS_EVENT_ON_CHILD); |
157 | send = (entry->mask & mask); | 157 | send = (fsn_mark->mask & mask); |
158 | 158 | ||
159 | /* find took a reference */ | 159 | /* find took a reference */ |
160 | fsnotify_put_mark(entry); | 160 | fsnotify_put_mark(fsn_mark); |
161 | 161 | ||
162 | return send; | 162 | return send; |
163 | } | 163 | } |
@@ -171,18 +171,18 @@ static bool inotify_should_send_event(struct fsnotify_group *group, struct inode | |||
171 | */ | 171 | */ |
172 | static int idr_callback(int id, void *p, void *data) | 172 | static int idr_callback(int id, void *p, void *data) |
173 | { | 173 | { |
174 | struct fsnotify_mark *entry; | 174 | struct fsnotify_mark *fsn_mark; |
175 | struct inotify_inode_mark_entry *ientry; | 175 | struct inotify_inode_mark *i_mark; |
176 | static bool warned = false; | 176 | static bool warned = false; |
177 | 177 | ||
178 | if (warned) | 178 | if (warned) |
179 | return 0; | 179 | return 0; |
180 | 180 | ||
181 | warned = true; | 181 | warned = true; |
182 | entry = p; | 182 | fsn_mark = p; |
183 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); | 183 | i_mark = container_of(fsn_mark, struct inotify_inode_mark, fsn_mark); |
184 | 184 | ||
185 | WARN(1, "inotify closing but id=%d for entry=%p in group=%p still in " | 185 | WARN(1, "inotify closing but id=%d for fsn_mark=%p in group=%p still in " |
186 | "idr. Probably leaking memory\n", id, p, data); | 186 | "idr. Probably leaking memory\n", id, p, data); |
187 | 187 | ||
188 | /* | 188 | /* |
@@ -191,9 +191,9 @@ static int idr_callback(int id, void *p, void *data) | |||
191 | * out why we got here and the panic is no worse than the original | 191 | * out why we got here and the panic is no worse than the original |
192 | * BUG() that was here. | 192 | * BUG() that was here. |
193 | */ | 193 | */ |
194 | if (entry) | 194 | if (fsn_mark) |
195 | printk(KERN_WARNING "entry->group=%p inode=%p wd=%d\n", | 195 | printk(KERN_WARNING "fsn_mark->group=%p inode=%p wd=%d\n", |
196 | entry->group, entry->i.inode, ientry->wd); | 196 | fsn_mark->group, fsn_mark->i.inode, i_mark->wd); |
197 | return 0; | 197 | return 0; |
198 | } | 198 | } |
199 | 199 | ||
diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c index 118085c9d2d9..80d102acb86b 100644 --- a/fs/notify/inotify/inotify_user.c +++ b/fs/notify/inotify/inotify_user.c | |||
@@ -353,7 +353,7 @@ static int inotify_find_inode(const char __user *dirname, struct path *path, uns | |||
353 | 353 | ||
354 | static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock, | 354 | static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock, |
355 | int *last_wd, | 355 | int *last_wd, |
356 | struct inotify_inode_mark_entry *ientry) | 356 | struct inotify_inode_mark *i_mark) |
357 | { | 357 | { |
358 | int ret; | 358 | int ret; |
359 | 359 | ||
@@ -362,12 +362,12 @@ static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock, | |||
362 | return -ENOMEM; | 362 | return -ENOMEM; |
363 | 363 | ||
364 | spin_lock(idr_lock); | 364 | spin_lock(idr_lock); |
365 | ret = idr_get_new_above(idr, ientry, *last_wd + 1, | 365 | ret = idr_get_new_above(idr, i_mark, *last_wd + 1, |
366 | &ientry->wd); | 366 | &i_mark->wd); |
367 | /* we added the mark to the idr, take a reference */ | 367 | /* we added the mark to the idr, take a reference */ |
368 | if (!ret) { | 368 | if (!ret) { |
369 | fsnotify_get_mark(&ientry->fsn_entry); | 369 | *last_wd = i_mark->wd; |
370 | *last_wd = ientry->wd; | 370 | fsnotify_get_mark(&i_mark->fsn_mark); |
371 | } | 371 | } |
372 | spin_unlock(idr_lock); | 372 | spin_unlock(idr_lock); |
373 | } while (ret == -EAGAIN); | 373 | } while (ret == -EAGAIN); |
@@ -375,53 +375,53 @@ static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock, | |||
375 | return ret; | 375 | return ret; |
376 | } | 376 | } |
377 | 377 | ||
378 | static struct inotify_inode_mark_entry *inotify_idr_find_locked(struct fsnotify_group *group, | 378 | static struct inotify_inode_mark *inotify_idr_find_locked(struct fsnotify_group *group, |
379 | int wd) | 379 | int wd) |
380 | { | 380 | { |
381 | struct idr *idr = &group->inotify_data.idr; | 381 | struct idr *idr = &group->inotify_data.idr; |
382 | spinlock_t *idr_lock = &group->inotify_data.idr_lock; | 382 | spinlock_t *idr_lock = &group->inotify_data.idr_lock; |
383 | struct inotify_inode_mark_entry *ientry; | 383 | struct inotify_inode_mark *i_mark; |
384 | 384 | ||
385 | assert_spin_locked(idr_lock); | 385 | assert_spin_locked(idr_lock); |
386 | 386 | ||
387 | ientry = idr_find(idr, wd); | 387 | i_mark = idr_find(idr, wd); |
388 | if (ientry) { | 388 | if (i_mark) { |
389 | struct fsnotify_mark *fsn_entry = &ientry->fsn_entry; | 389 | struct fsnotify_mark *fsn_mark = &i_mark->fsn_mark; |
390 | 390 | ||
391 | fsnotify_get_mark(fsn_entry); | 391 | fsnotify_get_mark(fsn_mark); |
392 | /* One ref for being in the idr, one ref we just took */ | 392 | /* One ref for being in the idr, one ref we just took */ |
393 | BUG_ON(atomic_read(&fsn_entry->refcnt) < 2); | 393 | BUG_ON(atomic_read(&fsn_mark->refcnt) < 2); |
394 | } | 394 | } |
395 | 395 | ||
396 | return ientry; | 396 | return i_mark; |
397 | } | 397 | } |
398 | 398 | ||
399 | static struct inotify_inode_mark_entry *inotify_idr_find(struct fsnotify_group *group, | 399 | static struct inotify_inode_mark *inotify_idr_find(struct fsnotify_group *group, |
400 | int wd) | 400 | int wd) |
401 | { | 401 | { |
402 | struct inotify_inode_mark_entry *ientry; | 402 | struct inotify_inode_mark *i_mark; |
403 | spinlock_t *idr_lock = &group->inotify_data.idr_lock; | 403 | spinlock_t *idr_lock = &group->inotify_data.idr_lock; |
404 | 404 | ||
405 | spin_lock(idr_lock); | 405 | spin_lock(idr_lock); |
406 | ientry = inotify_idr_find_locked(group, wd); | 406 | i_mark = inotify_idr_find_locked(group, wd); |
407 | spin_unlock(idr_lock); | 407 | spin_unlock(idr_lock); |
408 | 408 | ||
409 | return ientry; | 409 | return i_mark; |
410 | } | 410 | } |
411 | 411 | ||
412 | static void do_inotify_remove_from_idr(struct fsnotify_group *group, | 412 | static void do_inotify_remove_from_idr(struct fsnotify_group *group, |
413 | struct inotify_inode_mark_entry *ientry) | 413 | struct inotify_inode_mark *i_mark) |
414 | { | 414 | { |
415 | struct idr *idr = &group->inotify_data.idr; | 415 | struct idr *idr = &group->inotify_data.idr; |
416 | spinlock_t *idr_lock = &group->inotify_data.idr_lock; | 416 | spinlock_t *idr_lock = &group->inotify_data.idr_lock; |
417 | int wd = ientry->wd; | 417 | int wd = i_mark->wd; |
418 | 418 | ||
419 | assert_spin_locked(idr_lock); | 419 | assert_spin_locked(idr_lock); |
420 | 420 | ||
421 | idr_remove(idr, wd); | 421 | idr_remove(idr, wd); |
422 | 422 | ||
423 | /* removed from the idr, drop that ref */ | 423 | /* removed from the idr, drop that ref */ |
424 | fsnotify_put_mark(&ientry->fsn_entry); | 424 | fsnotify_put_mark(&i_mark->fsn_mark); |
425 | } | 425 | } |
426 | 426 | ||
427 | /* | 427 | /* |
@@ -429,48 +429,48 @@ static void do_inotify_remove_from_idr(struct fsnotify_group *group, | |||
429 | * on the mark because it was in the idr. | 429 | * on the mark because it was in the idr. |
430 | */ | 430 | */ |
431 | static void inotify_remove_from_idr(struct fsnotify_group *group, | 431 | static void inotify_remove_from_idr(struct fsnotify_group *group, |
432 | struct inotify_inode_mark_entry *ientry) | 432 | struct inotify_inode_mark *i_mark) |
433 | { | 433 | { |
434 | spinlock_t *idr_lock = &group->inotify_data.idr_lock; | 434 | spinlock_t *idr_lock = &group->inotify_data.idr_lock; |
435 | struct inotify_inode_mark_entry *found_ientry = NULL; | 435 | struct inotify_inode_mark *found_i_mark = NULL; |
436 | int wd; | 436 | int wd; |
437 | 437 | ||
438 | spin_lock(idr_lock); | 438 | spin_lock(idr_lock); |
439 | wd = ientry->wd; | 439 | wd = i_mark->wd; |
440 | 440 | ||
441 | /* | 441 | /* |
442 | * does this ientry think it is in the idr? we shouldn't get called | 442 | * does this i_mark think it is in the idr? we shouldn't get called |
443 | * if it wasn't.... | 443 | * if it wasn't.... |
444 | */ | 444 | */ |
445 | if (wd == -1) { | 445 | if (wd == -1) { |
446 | WARN_ONCE(1, "%s: ientry=%p ientry->wd=%d ientry->group=%p" | 446 | WARN_ONCE(1, "%s: i_mark=%p i_mark->wd=%d i_mark->group=%p" |
447 | " ientry->inode=%p\n", __func__, ientry, ientry->wd, | 447 | " i_mark->inode=%p\n", __func__, i_mark, i_mark->wd, |
448 | ientry->fsn_entry.group, ientry->fsn_entry.i.inode); | 448 | i_mark->fsn_mark.group, i_mark->fsn_mark.i.inode); |
449 | goto out; | 449 | goto out; |
450 | } | 450 | } |
451 | 451 | ||
452 | /* Lets look in the idr to see if we find it */ | 452 | /* Lets look in the idr to see if we find it */ |
453 | found_ientry = inotify_idr_find_locked(group, wd); | 453 | found_i_mark = inotify_idr_find_locked(group, wd); |
454 | if (unlikely(!found_ientry)) { | 454 | if (unlikely(!found_i_mark)) { |
455 | WARN_ONCE(1, "%s: ientry=%p ientry->wd=%d ientry->group=%p" | 455 | WARN_ONCE(1, "%s: i_mark=%p i_mark->wd=%d i_mark->group=%p" |
456 | " ientry->inode=%p\n", __func__, ientry, ientry->wd, | 456 | " i_mark->inode=%p\n", __func__, i_mark, i_mark->wd, |
457 | ientry->fsn_entry.group, ientry->fsn_entry.i.inode); | 457 | i_mark->fsn_mark.group, i_mark->fsn_mark.i.inode); |
458 | goto out; | 458 | goto out; |
459 | } | 459 | } |
460 | 460 | ||
461 | /* | 461 | /* |
462 | * We found an entry in the idr at the right wd, but it's | 462 | * We found an mark in the idr at the right wd, but it's |
463 | * not the entry we were told to remove. eparis seriously | 463 | * not the mark we were told to remove. eparis seriously |
464 | * fucked up somewhere. | 464 | * fucked up somewhere. |
465 | */ | 465 | */ |
466 | if (unlikely(found_ientry != ientry)) { | 466 | if (unlikely(found_i_mark != i_mark)) { |
467 | WARN_ONCE(1, "%s: ientry=%p ientry->wd=%d ientry->group=%p " | 467 | WARN_ONCE(1, "%s: i_mark=%p i_mark->wd=%d i_mark->group=%p " |
468 | "entry->inode=%p found_ientry=%p found_ientry->wd=%d " | 468 | "mark->inode=%p found_i_mark=%p found_i_mark->wd=%d " |
469 | "found_ientry->group=%p found_ientry->inode=%p\n", | 469 | "found_i_mark->group=%p found_i_mark->inode=%p\n", |
470 | __func__, ientry, ientry->wd, ientry->fsn_entry.group, | 470 | __func__, i_mark, i_mark->wd, i_mark->fsn_mark.group, |
471 | ientry->fsn_entry.i.inode, found_ientry, found_ientry->wd, | 471 | i_mark->fsn_mark.i.inode, found_i_mark, found_i_mark->wd, |
472 | found_ientry->fsn_entry.group, | 472 | found_i_mark->fsn_mark.group, |
473 | found_ientry->fsn_entry.i.inode); | 473 | found_i_mark->fsn_mark.i.inode); |
474 | goto out; | 474 | goto out; |
475 | } | 475 | } |
476 | 476 | ||
@@ -479,30 +479,30 @@ static void inotify_remove_from_idr(struct fsnotify_group *group, | |||
479 | * one ref held by the caller trying to kill us | 479 | * one ref held by the caller trying to kill us |
480 | * one ref grabbed by inotify_idr_find | 480 | * one ref grabbed by inotify_idr_find |
481 | */ | 481 | */ |
482 | if (unlikely(atomic_read(&ientry->fsn_entry.refcnt) < 3)) { | 482 | if (unlikely(atomic_read(&i_mark->fsn_mark.refcnt) < 3)) { |
483 | printk(KERN_ERR "%s: ientry=%p ientry->wd=%d ientry->group=%p" | 483 | printk(KERN_ERR "%s: i_mark=%p i_mark->wd=%d i_mark->group=%p" |
484 | " ientry->inode=%p\n", __func__, ientry, ientry->wd, | 484 | " i_mark->inode=%p\n", __func__, i_mark, i_mark->wd, |
485 | ientry->fsn_entry.group, ientry->fsn_entry.i.inode); | 485 | i_mark->fsn_mark.group, i_mark->fsn_mark.i.inode); |
486 | /* we can't really recover with bad ref cnting.. */ | 486 | /* we can't really recover with bad ref cnting.. */ |
487 | BUG(); | 487 | BUG(); |
488 | } | 488 | } |
489 | 489 | ||
490 | do_inotify_remove_from_idr(group, ientry); | 490 | do_inotify_remove_from_idr(group, i_mark); |
491 | out: | 491 | out: |
492 | /* match the ref taken by inotify_idr_find_locked() */ | 492 | /* match the ref taken by inotify_idr_find_locked() */ |
493 | if (found_ientry) | 493 | if (found_i_mark) |
494 | fsnotify_put_mark(&found_ientry->fsn_entry); | 494 | fsnotify_put_mark(&found_i_mark->fsn_mark); |
495 | ientry->wd = -1; | 495 | i_mark->wd = -1; |
496 | spin_unlock(idr_lock); | 496 | spin_unlock(idr_lock); |
497 | } | 497 | } |
498 | 498 | ||
499 | /* | 499 | /* |
500 | * Send IN_IGNORED for this wd, remove this wd from the idr. | 500 | * Send IN_IGNORED for this wd, remove this wd from the idr. |
501 | */ | 501 | */ |
502 | void inotify_ignored_and_remove_idr(struct fsnotify_mark *entry, | 502 | void inotify_ignored_and_remove_idr(struct fsnotify_mark *fsn_mark, |
503 | struct fsnotify_group *group) | 503 | struct fsnotify_group *group) |
504 | { | 504 | { |
505 | struct inotify_inode_mark_entry *ientry; | 505 | struct inotify_inode_mark *i_mark; |
506 | struct fsnotify_event *ignored_event; | 506 | struct fsnotify_event *ignored_event; |
507 | struct inotify_event_private_data *event_priv; | 507 | struct inotify_event_private_data *event_priv; |
508 | struct fsnotify_event_private_data *fsn_event_priv; | 508 | struct fsnotify_event_private_data *fsn_event_priv; |
@@ -514,7 +514,7 @@ void inotify_ignored_and_remove_idr(struct fsnotify_mark *entry, | |||
514 | if (!ignored_event) | 514 | if (!ignored_event) |
515 | return; | 515 | return; |
516 | 516 | ||
517 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); | 517 | i_mark = container_of(fsn_mark, struct inotify_inode_mark, fsn_mark); |
518 | 518 | ||
519 | event_priv = kmem_cache_alloc(event_priv_cachep, GFP_NOFS); | 519 | event_priv = kmem_cache_alloc(event_priv_cachep, GFP_NOFS); |
520 | if (unlikely(!event_priv)) | 520 | if (unlikely(!event_priv)) |
@@ -523,7 +523,7 @@ void inotify_ignored_and_remove_idr(struct fsnotify_mark *entry, | |||
523 | fsn_event_priv = &event_priv->fsnotify_event_priv_data; | 523 | fsn_event_priv = &event_priv->fsnotify_event_priv_data; |
524 | 524 | ||
525 | fsn_event_priv->group = group; | 525 | fsn_event_priv->group = group; |
526 | event_priv->wd = ientry->wd; | 526 | event_priv->wd = i_mark->wd; |
527 | 527 | ||
528 | ret = fsnotify_add_notify_event(group, ignored_event, fsn_event_priv, NULL); | 528 | ret = fsnotify_add_notify_event(group, ignored_event, fsn_event_priv, NULL); |
529 | if (ret) | 529 | if (ret) |
@@ -534,28 +534,28 @@ skip_send_ignore: | |||
534 | /* matches the reference taken when the event was created */ | 534 | /* matches the reference taken when the event was created */ |
535 | fsnotify_put_event(ignored_event); | 535 | fsnotify_put_event(ignored_event); |
536 | 536 | ||
537 | /* remove this entry from the idr */ | 537 | /* remove this mark from the idr */ |
538 | inotify_remove_from_idr(group, ientry); | 538 | inotify_remove_from_idr(group, i_mark); |
539 | 539 | ||
540 | atomic_dec(&group->inotify_data.user->inotify_watches); | 540 | atomic_dec(&group->inotify_data.user->inotify_watches); |
541 | } | 541 | } |
542 | 542 | ||
543 | /* ding dong the mark is dead */ | 543 | /* ding dong the mark is dead */ |
544 | static void inotify_free_mark(struct fsnotify_mark *entry) | 544 | static void inotify_free_mark(struct fsnotify_mark *fsn_mark) |
545 | { | 545 | { |
546 | struct inotify_inode_mark_entry *ientry; | 546 | struct inotify_inode_mark *i_mark; |
547 | 547 | ||
548 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); | 548 | i_mark = container_of(fsn_mark, struct inotify_inode_mark, fsn_mark); |
549 | 549 | ||
550 | kmem_cache_free(inotify_inode_mark_cachep, ientry); | 550 | kmem_cache_free(inotify_inode_mark_cachep, i_mark); |
551 | } | 551 | } |
552 | 552 | ||
553 | static int inotify_update_existing_watch(struct fsnotify_group *group, | 553 | static int inotify_update_existing_watch(struct fsnotify_group *group, |
554 | struct inode *inode, | 554 | struct inode *inode, |
555 | u32 arg) | 555 | u32 arg) |
556 | { | 556 | { |
557 | struct fsnotify_mark *entry; | 557 | struct fsnotify_mark *fsn_mark; |
558 | struct inotify_inode_mark_entry *ientry; | 558 | struct inotify_inode_mark *i_mark; |
559 | __u32 old_mask, new_mask; | 559 | __u32 old_mask, new_mask; |
560 | __u32 mask; | 560 | __u32 mask; |
561 | int add = (arg & IN_MASK_ADD); | 561 | int add = (arg & IN_MASK_ADD); |
@@ -567,35 +567,35 @@ static int inotify_update_existing_watch(struct fsnotify_group *group, | |||
567 | return -EINVAL; | 567 | return -EINVAL; |
568 | 568 | ||
569 | spin_lock(&inode->i_lock); | 569 | spin_lock(&inode->i_lock); |
570 | entry = fsnotify_find_mark(group, inode); | 570 | fsn_mark = fsnotify_find_mark(group, inode); |
571 | spin_unlock(&inode->i_lock); | 571 | spin_unlock(&inode->i_lock); |
572 | if (!entry) | 572 | if (!fsn_mark) |
573 | return -ENOENT; | 573 | return -ENOENT; |
574 | 574 | ||
575 | ientry = container_of(entry, struct inotify_inode_mark_entry, fsn_entry); | 575 | i_mark = container_of(fsn_mark, struct inotify_inode_mark, fsn_mark); |
576 | 576 | ||
577 | spin_lock(&entry->lock); | 577 | spin_lock(&fsn_mark->lock); |
578 | 578 | ||
579 | old_mask = entry->mask; | 579 | old_mask = fsn_mark->mask; |
580 | if (add) { | 580 | if (add) { |
581 | entry->mask |= mask; | 581 | fsn_mark->mask |= mask; |
582 | new_mask = entry->mask; | 582 | new_mask = fsn_mark->mask; |
583 | } else { | 583 | } else { |
584 | entry->mask = mask; | 584 | fsn_mark->mask = mask; |
585 | new_mask = entry->mask; | 585 | new_mask = fsn_mark->mask; |
586 | } | 586 | } |
587 | 587 | ||
588 | spin_unlock(&entry->lock); | 588 | spin_unlock(&fsn_mark->lock); |
589 | 589 | ||
590 | if (old_mask != new_mask) { | 590 | if (old_mask != new_mask) { |
591 | /* more bits in old than in new? */ | 591 | /* more bits in old than in new? */ |
592 | int dropped = (old_mask & ~new_mask); | 592 | int dropped = (old_mask & ~new_mask); |
593 | /* more bits in this entry than the inode's mask? */ | 593 | /* more bits in this fsn_mark than the inode's mask? */ |
594 | int do_inode = (new_mask & ~inode->i_fsnotify_mask); | 594 | int do_inode = (new_mask & ~inode->i_fsnotify_mask); |
595 | /* more bits in this entry than the group? */ | 595 | /* more bits in this fsn_mark than the group? */ |
596 | int do_group = (new_mask & ~group->mask); | 596 | int do_group = (new_mask & ~group->mask); |
597 | 597 | ||
598 | /* update the inode with this new entry */ | 598 | /* update the inode with this new fsn_mark */ |
599 | if (dropped || do_inode) | 599 | if (dropped || do_inode) |
600 | fsnotify_recalc_inode_mask(inode); | 600 | fsnotify_recalc_inode_mask(inode); |
601 | 601 | ||
@@ -605,10 +605,10 @@ static int inotify_update_existing_watch(struct fsnotify_group *group, | |||
605 | } | 605 | } |
606 | 606 | ||
607 | /* return the wd */ | 607 | /* return the wd */ |
608 | ret = ientry->wd; | 608 | ret = i_mark->wd; |
609 | 609 | ||
610 | /* match the get from fsnotify_find_mark() */ | 610 | /* match the get from fsnotify_find_mark() */ |
611 | fsnotify_put_mark(entry); | 611 | fsnotify_put_mark(fsn_mark); |
612 | 612 | ||
613 | return ret; | 613 | return ret; |
614 | } | 614 | } |
@@ -617,7 +617,7 @@ static int inotify_new_watch(struct fsnotify_group *group, | |||
617 | struct inode *inode, | 617 | struct inode *inode, |
618 | u32 arg) | 618 | u32 arg) |
619 | { | 619 | { |
620 | struct inotify_inode_mark_entry *tmp_ientry; | 620 | struct inotify_inode_mark *tmp_i_mark; |
621 | __u32 mask; | 621 | __u32 mask; |
622 | int ret; | 622 | int ret; |
623 | struct idr *idr = &group->inotify_data.idr; | 623 | struct idr *idr = &group->inotify_data.idr; |
@@ -628,44 +628,44 @@ static int inotify_new_watch(struct fsnotify_group *group, | |||
628 | if (unlikely(!mask)) | 628 | if (unlikely(!mask)) |
629 | return -EINVAL; | 629 | return -EINVAL; |
630 | 630 | ||
631 | tmp_ientry = kmem_cache_alloc(inotify_inode_mark_cachep, GFP_KERNEL); | 631 | tmp_i_mark = kmem_cache_alloc(inotify_inode_mark_cachep, GFP_KERNEL); |
632 | if (unlikely(!tmp_ientry)) | 632 | if (unlikely(!tmp_i_mark)) |
633 | return -ENOMEM; | 633 | return -ENOMEM; |
634 | 634 | ||
635 | fsnotify_init_mark(&tmp_ientry->fsn_entry, inotify_free_mark); | 635 | fsnotify_init_mark(&tmp_i_mark->fsn_mark, inotify_free_mark); |
636 | tmp_ientry->fsn_entry.mask = mask; | 636 | tmp_i_mark->fsn_mark.mask = mask; |
637 | tmp_ientry->wd = -1; | 637 | tmp_i_mark->wd = -1; |
638 | 638 | ||
639 | ret = -ENOSPC; | 639 | ret = -ENOSPC; |
640 | if (atomic_read(&group->inotify_data.user->inotify_watches) >= inotify_max_user_watches) | 640 | if (atomic_read(&group->inotify_data.user->inotify_watches) >= inotify_max_user_watches) |
641 | goto out_err; | 641 | goto out_err; |
642 | 642 | ||
643 | ret = inotify_add_to_idr(idr, idr_lock, &group->inotify_data.last_wd, | 643 | ret = inotify_add_to_idr(idr, idr_lock, &group->inotify_data.last_wd, |
644 | tmp_ientry); | 644 | tmp_i_mark); |
645 | if (ret) | 645 | if (ret) |
646 | goto out_err; | 646 | goto out_err; |
647 | 647 | ||
648 | /* we are on the idr, now get on the inode */ | 648 | /* we are on the idr, now get on the inode */ |
649 | ret = fsnotify_add_mark(&tmp_ientry->fsn_entry, group, inode, 0); | 649 | ret = fsnotify_add_mark(&tmp_i_mark->fsn_mark, group, inode, 0); |
650 | if (ret) { | 650 | if (ret) { |
651 | /* we failed to get on the inode, get off the idr */ | 651 | /* we failed to get on the inode, get off the idr */ |
652 | inotify_remove_from_idr(group, tmp_ientry); | 652 | inotify_remove_from_idr(group, tmp_i_mark); |
653 | goto out_err; | 653 | goto out_err; |
654 | } | 654 | } |
655 | 655 | ||
656 | /* increment the number of watches the user has */ | 656 | /* increment the number of watches the user has */ |
657 | atomic_inc(&group->inotify_data.user->inotify_watches); | 657 | atomic_inc(&group->inotify_data.user->inotify_watches); |
658 | 658 | ||
659 | /* return the watch descriptor for this new entry */ | 659 | /* return the watch descriptor for this new mark */ |
660 | ret = tmp_ientry->wd; | 660 | ret = tmp_i_mark->wd; |
661 | 661 | ||
662 | /* if this mark added a new event update the group mask */ | 662 | /* if this mark added a new event update the group mask */ |
663 | if (mask & ~group->mask) | 663 | if (mask & ~group->mask) |
664 | fsnotify_recalc_group_mask(group); | 664 | fsnotify_recalc_group_mask(group); |
665 | 665 | ||
666 | out_err: | 666 | out_err: |
667 | /* match the ref from fsnotify_init_markentry() */ | 667 | /* match the ref from fsnotify_init_mark() */ |
668 | fsnotify_put_mark(&tmp_ientry->fsn_entry); | 668 | fsnotify_put_mark(&tmp_i_mark->fsn_mark); |
669 | 669 | ||
670 | return ret; | 670 | return ret; |
671 | } | 671 | } |
@@ -801,7 +801,7 @@ fput_and_out: | |||
801 | SYSCALL_DEFINE2(inotify_rm_watch, int, fd, __s32, wd) | 801 | SYSCALL_DEFINE2(inotify_rm_watch, int, fd, __s32, wd) |
802 | { | 802 | { |
803 | struct fsnotify_group *group; | 803 | struct fsnotify_group *group; |
804 | struct inotify_inode_mark_entry *ientry; | 804 | struct inotify_inode_mark *i_mark; |
805 | struct file *filp; | 805 | struct file *filp; |
806 | int ret = 0, fput_needed; | 806 | int ret = 0, fput_needed; |
807 | 807 | ||
@@ -817,16 +817,16 @@ SYSCALL_DEFINE2(inotify_rm_watch, int, fd, __s32, wd) | |||
817 | group = filp->private_data; | 817 | group = filp->private_data; |
818 | 818 | ||
819 | ret = -EINVAL; | 819 | ret = -EINVAL; |
820 | ientry = inotify_idr_find(group, wd); | 820 | i_mark = inotify_idr_find(group, wd); |
821 | if (unlikely(!ientry)) | 821 | if (unlikely(!i_mark)) |
822 | goto out; | 822 | goto out; |
823 | 823 | ||
824 | ret = 0; | 824 | ret = 0; |
825 | 825 | ||
826 | fsnotify_destroy_mark(&ientry->fsn_entry); | 826 | fsnotify_destroy_mark(&i_mark->fsn_mark); |
827 | 827 | ||
828 | /* match ref taken by inotify_idr_find */ | 828 | /* match ref taken by inotify_idr_find */ |
829 | fsnotify_put_mark(&ientry->fsn_entry); | 829 | fsnotify_put_mark(&i_mark->fsn_mark); |
830 | 830 | ||
831 | out: | 831 | out: |
832 | fput_light(filp, fput_needed); | 832 | fput_light(filp, fput_needed); |
@@ -840,7 +840,7 @@ out: | |||
840 | */ | 840 | */ |
841 | static int __init inotify_user_setup(void) | 841 | static int __init inotify_user_setup(void) |
842 | { | 842 | { |
843 | inotify_inode_mark_cachep = KMEM_CACHE(inotify_inode_mark_entry, SLAB_PANIC); | 843 | inotify_inode_mark_cachep = KMEM_CACHE(inotify_inode_mark, SLAB_PANIC); |
844 | event_priv_cachep = KMEM_CACHE(inotify_event_private_data, SLAB_PANIC); | 844 | event_priv_cachep = KMEM_CACHE(inotify_event_private_data, SLAB_PANIC); |
845 | 845 | ||
846 | inotify_max_queued_events = 16384; | 846 | inotify_max_queued_events = 16384; |