diff options
-rw-r--r-- | fs/xfs/linux-2.6/xfs_vnode.c | 14 | ||||
-rw-r--r-- | fs/xfs/linux-2.6/xfs_vnode.h | 6 | ||||
-rw-r--r-- | fs/xfs/xfs_iget.c | 142 | ||||
-rw-r--r-- | fs/xfs/xfs_inode.h | 1 |
4 files changed, 65 insertions, 98 deletions
diff --git a/fs/xfs/linux-2.6/xfs_vnode.c b/fs/xfs/linux-2.6/xfs_vnode.c index d42a33cd9d3..8f0f74fc703 100644 --- a/fs/xfs/linux-2.6/xfs_vnode.c +++ b/fs/xfs/linux-2.6/xfs_vnode.c | |||
@@ -82,20 +82,6 @@ vn_ioerror( | |||
82 | xfs_do_force_shutdown(ip->i_mount, SHUTDOWN_DEVICE_REQ, f, l); | 82 | xfs_do_force_shutdown(ip->i_mount, SHUTDOWN_DEVICE_REQ, f, l); |
83 | } | 83 | } |
84 | 84 | ||
85 | bhv_vnode_t * | ||
86 | vn_initialize( | ||
87 | struct inode *inode) | ||
88 | { | ||
89 | bhv_vnode_t *vp = vn_from_inode(inode); | ||
90 | |||
91 | XFS_STATS_INC(vn_active); | ||
92 | XFS_STATS_INC(vn_alloc); | ||
93 | |||
94 | ASSERT(VN_CACHED(vp) == 0); | ||
95 | |||
96 | return vp; | ||
97 | } | ||
98 | |||
99 | /* | 85 | /* |
100 | * Revalidate the Linux inode from the XFS inode. | 86 | * Revalidate the Linux inode from the XFS inode. |
101 | * Note: i_size _not_ updated; we must hold the inode | 87 | * Note: i_size _not_ updated; we must hold the inode |
diff --git a/fs/xfs/linux-2.6/xfs_vnode.h b/fs/xfs/linux-2.6/xfs_vnode.h index 59cbe4035d4..b5ea418693b 100644 --- a/fs/xfs/linux-2.6/xfs_vnode.h +++ b/fs/xfs/linux-2.6/xfs_vnode.h | |||
@@ -187,7 +187,6 @@ typedef struct bhv_vattr { | |||
187 | (VN_ISREG(vp) && ((mode) & (VSGID|(VEXEC>>3))) == VSGID) | 187 | (VN_ISREG(vp) && ((mode) & (VSGID|(VEXEC>>3))) == VSGID) |
188 | 188 | ||
189 | extern void vn_init(void); | 189 | extern void vn_init(void); |
190 | extern bhv_vnode_t *vn_initialize(struct inode *); | ||
191 | extern int vn_revalidate(bhv_vnode_t *); | 190 | extern int vn_revalidate(bhv_vnode_t *); |
192 | 191 | ||
193 | /* | 192 | /* |
@@ -236,11 +235,6 @@ static inline bhv_vnode_t *vn_grab(bhv_vnode_t *vp) | |||
236 | /* | 235 | /* |
237 | * Dealing with bad inodes | 236 | * Dealing with bad inodes |
238 | */ | 237 | */ |
239 | static inline void vn_mark_bad(bhv_vnode_t *vp) | ||
240 | { | ||
241 | make_bad_inode(vn_to_inode(vp)); | ||
242 | } | ||
243 | |||
244 | static inline int VN_BAD(bhv_vnode_t *vp) | 238 | static inline int VN_BAD(bhv_vnode_t *vp) |
245 | { | 239 | { |
246 | return is_bad_inode(vn_to_inode(vp)); | 240 | return is_bad_inode(vn_to_inode(vp)); |
diff --git a/fs/xfs/xfs_iget.c b/fs/xfs/xfs_iget.c index 15dba2ef847..eecc33d3751 100644 --- a/fs/xfs/xfs_iget.c +++ b/fs/xfs/xfs_iget.c | |||
@@ -65,7 +65,7 @@ | |||
65 | */ | 65 | */ |
66 | STATIC int | 66 | STATIC int |
67 | xfs_iget_core( | 67 | xfs_iget_core( |
68 | bhv_vnode_t *vp, | 68 | struct inode *inode, |
69 | xfs_mount_t *mp, | 69 | xfs_mount_t *mp, |
70 | xfs_trans_t *tp, | 70 | xfs_trans_t *tp, |
71 | xfs_ino_t ino, | 71 | xfs_ino_t ino, |
@@ -74,9 +74,9 @@ xfs_iget_core( | |||
74 | xfs_inode_t **ipp, | 74 | xfs_inode_t **ipp, |
75 | xfs_daddr_t bno) | 75 | xfs_daddr_t bno) |
76 | { | 76 | { |
77 | struct inode *old_inode; | ||
77 | xfs_inode_t *ip; | 78 | xfs_inode_t *ip; |
78 | xfs_inode_t *iq; | 79 | xfs_inode_t *iq; |
79 | bhv_vnode_t *inode_vp; | ||
80 | int error; | 80 | int error; |
81 | xfs_icluster_t *icl, *new_icl = NULL; | 81 | xfs_icluster_t *icl, *new_icl = NULL; |
82 | unsigned long first_index, mask; | 82 | unsigned long first_index, mask; |
@@ -111,8 +111,8 @@ again: | |||
111 | goto again; | 111 | goto again; |
112 | } | 112 | } |
113 | 113 | ||
114 | inode_vp = XFS_ITOV_NULL(ip); | 114 | old_inode = ip->i_vnode; |
115 | if (inode_vp == NULL) { | 115 | if (old_inode == NULL) { |
116 | /* | 116 | /* |
117 | * If IRECLAIM is set this inode is | 117 | * If IRECLAIM is set this inode is |
118 | * on its way out of the system, | 118 | * on its way out of the system, |
@@ -170,13 +170,11 @@ again: | |||
170 | 170 | ||
171 | goto finish_inode; | 171 | goto finish_inode; |
172 | 172 | ||
173 | } else if (vp != inode_vp) { | 173 | } else if (inode != old_inode) { |
174 | struct inode *inode = vn_to_inode(inode_vp); | ||
175 | |||
176 | /* The inode is being torn down, pause and | 174 | /* The inode is being torn down, pause and |
177 | * try again. | 175 | * try again. |
178 | */ | 176 | */ |
179 | if (inode->i_state & (I_FREEING | I_CLEAR)) { | 177 | if (old_inode->i_state & (I_FREEING | I_CLEAR)) { |
180 | read_unlock(&pag->pag_ici_lock); | 178 | read_unlock(&pag->pag_ici_lock); |
181 | delay(1); | 179 | delay(1); |
182 | XFS_STATS_INC(xs_ig_frecycle); | 180 | XFS_STATS_INC(xs_ig_frecycle); |
@@ -189,7 +187,7 @@ again: | |||
189 | */ | 187 | */ |
190 | cmn_err(CE_PANIC, | 188 | cmn_err(CE_PANIC, |
191 | "xfs_iget_core: ambiguous vns: vp/0x%p, invp/0x%p", | 189 | "xfs_iget_core: ambiguous vns: vp/0x%p, invp/0x%p", |
192 | inode_vp, vp); | 190 | old_inode, inode); |
193 | } | 191 | } |
194 | 192 | ||
195 | /* | 193 | /* |
@@ -231,7 +229,14 @@ finish_inode: | |||
231 | 229 | ||
232 | xfs_itrace_exit_tag(ip, "xfs_iget.alloc"); | 230 | xfs_itrace_exit_tag(ip, "xfs_iget.alloc"); |
233 | 231 | ||
234 | xfs_inode_lock_init(ip, vp); | 232 | |
233 | mrlock_init(&ip->i_lock, MRLOCK_ALLOW_EQUAL_PRI|MRLOCK_BARRIER, | ||
234 | "xfsino", ip->i_ino); | ||
235 | mrlock_init(&ip->i_iolock, MRLOCK_BARRIER, "xfsio", ip->i_ino); | ||
236 | init_waitqueue_head(&ip->i_ipin_wait); | ||
237 | atomic_set(&ip->i_pincount, 0); | ||
238 | initnsema(&ip->i_flock, 1, "xfsfino"); | ||
239 | |||
235 | if (lock_flags) | 240 | if (lock_flags) |
236 | xfs_ilock(ip, lock_flags); | 241 | xfs_ilock(ip, lock_flags); |
237 | 242 | ||
@@ -334,7 +339,7 @@ finish_inode: | |||
334 | * If we have a real type for an on-disk inode, we can set ops(&unlock) | 339 | * If we have a real type for an on-disk inode, we can set ops(&unlock) |
335 | * now. If it's a new inode being created, xfs_ialloc will handle it. | 340 | * now. If it's a new inode being created, xfs_ialloc will handle it. |
336 | */ | 341 | */ |
337 | xfs_initialize_vnode(mp, vp, ip); | 342 | xfs_initialize_vnode(mp, inode, ip); |
338 | return 0; | 343 | return 0; |
339 | } | 344 | } |
340 | 345 | ||
@@ -354,69 +359,58 @@ xfs_iget( | |||
354 | xfs_daddr_t bno) | 359 | xfs_daddr_t bno) |
355 | { | 360 | { |
356 | struct inode *inode; | 361 | struct inode *inode; |
357 | bhv_vnode_t *vp = NULL; | 362 | xfs_inode_t *ip; |
358 | int error; | 363 | int error; |
359 | 364 | ||
360 | XFS_STATS_INC(xs_ig_attempts); | 365 | XFS_STATS_INC(xs_ig_attempts); |
361 | 366 | ||
362 | retry: | 367 | retry: |
363 | inode = iget_locked(mp->m_super, ino); | 368 | inode = iget_locked(mp->m_super, ino); |
364 | if (inode) { | 369 | if (!inode) |
365 | xfs_inode_t *ip; | 370 | /* If we got no inode we are out of memory */ |
366 | 371 | return ENOMEM; | |
367 | vp = vn_from_inode(inode); | 372 | |
368 | if (inode->i_state & I_NEW) { | 373 | if (inode->i_state & I_NEW) { |
369 | vn_initialize(inode); | 374 | XFS_STATS_INC(vn_active); |
370 | error = xfs_iget_core(vp, mp, tp, ino, flags, | 375 | XFS_STATS_INC(vn_alloc); |
371 | lock_flags, ipp, bno); | 376 | |
372 | if (error) { | 377 | error = xfs_iget_core(inode, mp, tp, ino, flags, |
373 | vn_mark_bad(vp); | 378 | lock_flags, ipp, bno); |
374 | if (inode->i_state & I_NEW) | 379 | if (error) { |
375 | unlock_new_inode(inode); | 380 | make_bad_inode(inode); |
376 | iput(inode); | 381 | if (inode->i_state & I_NEW) |
377 | } | 382 | unlock_new_inode(inode); |
378 | } else { | 383 | iput(inode); |
379 | /* | ||
380 | * If the inode is not fully constructed due to | ||
381 | * filehandle mismatches wait for the inode to go | ||
382 | * away and try again. | ||
383 | * | ||
384 | * iget_locked will call __wait_on_freeing_inode | ||
385 | * to wait for the inode to go away. | ||
386 | */ | ||
387 | if (is_bad_inode(inode) || | ||
388 | ((ip = xfs_vtoi(vp)) == NULL)) { | ||
389 | iput(inode); | ||
390 | delay(1); | ||
391 | goto retry; | ||
392 | } | ||
393 | |||
394 | if (lock_flags != 0) | ||
395 | xfs_ilock(ip, lock_flags); | ||
396 | XFS_STATS_INC(xs_ig_found); | ||
397 | *ipp = ip; | ||
398 | error = 0; | ||
399 | } | 384 | } |
400 | } else | 385 | return error; |
401 | error = ENOMEM; /* If we got no inode we are out of memory */ | 386 | } |
402 | 387 | ||
403 | return error; | 388 | /* |
404 | } | 389 | * If the inode is not fully constructed due to |
390 | * filehandle mismatches wait for the inode to go | ||
391 | * away and try again. | ||
392 | * | ||
393 | * iget_locked will call __wait_on_freeing_inode | ||
394 | * to wait for the inode to go away. | ||
395 | */ | ||
396 | if (is_bad_inode(inode)) { | ||
397 | iput(inode); | ||
398 | delay(1); | ||
399 | goto retry; | ||
400 | } | ||
405 | 401 | ||
406 | /* | 402 | ip = XFS_I(inode); |
407 | * Do the setup for the various locks within the incore inode. | 403 | if (!ip) { |
408 | */ | 404 | iput(inode); |
409 | void | 405 | delay(1); |
410 | xfs_inode_lock_init( | 406 | goto retry; |
411 | xfs_inode_t *ip, | 407 | } |
412 | bhv_vnode_t *vp) | 408 | |
413 | { | 409 | if (lock_flags != 0) |
414 | mrlock_init(&ip->i_lock, MRLOCK_ALLOW_EQUAL_PRI|MRLOCK_BARRIER, | 410 | xfs_ilock(ip, lock_flags); |
415 | "xfsino", ip->i_ino); | 411 | XFS_STATS_INC(xs_ig_found); |
416 | mrlock_init(&ip->i_iolock, MRLOCK_BARRIER, "xfsio", ip->i_ino); | 412 | *ipp = ip; |
417 | init_waitqueue_head(&ip->i_ipin_wait); | 413 | return 0; |
418 | atomic_set(&ip->i_pincount, 0); | ||
419 | initnsema(&ip->i_flock, 1, "xfsfino"); | ||
420 | } | 414 | } |
421 | 415 | ||
422 | /* | 416 | /* |
@@ -456,11 +450,9 @@ void | |||
456 | xfs_iput(xfs_inode_t *ip, | 450 | xfs_iput(xfs_inode_t *ip, |
457 | uint lock_flags) | 451 | uint lock_flags) |
458 | { | 452 | { |
459 | bhv_vnode_t *vp = XFS_ITOV(ip); | ||
460 | |||
461 | xfs_itrace_entry(ip); | 453 | xfs_itrace_entry(ip); |
462 | xfs_iunlock(ip, lock_flags); | 454 | xfs_iunlock(ip, lock_flags); |
463 | VN_RELE(vp); | 455 | IRELE(ip); |
464 | } | 456 | } |
465 | 457 | ||
466 | /* | 458 | /* |
@@ -470,20 +462,19 @@ void | |||
470 | xfs_iput_new(xfs_inode_t *ip, | 462 | xfs_iput_new(xfs_inode_t *ip, |
471 | uint lock_flags) | 463 | uint lock_flags) |
472 | { | 464 | { |
473 | bhv_vnode_t *vp = XFS_ITOV(ip); | 465 | struct inode *inode = ip->i_vnode; |
474 | struct inode *inode = vn_to_inode(vp); | ||
475 | 466 | ||
476 | xfs_itrace_entry(ip); | 467 | xfs_itrace_entry(ip); |
477 | 468 | ||
478 | if ((ip->i_d.di_mode == 0)) { | 469 | if ((ip->i_d.di_mode == 0)) { |
479 | ASSERT(!xfs_iflags_test(ip, XFS_IRECLAIMABLE)); | 470 | ASSERT(!xfs_iflags_test(ip, XFS_IRECLAIMABLE)); |
480 | vn_mark_bad(vp); | 471 | make_bad_inode(inode); |
481 | } | 472 | } |
482 | if (inode->i_state & I_NEW) | 473 | if (inode->i_state & I_NEW) |
483 | unlock_new_inode(inode); | 474 | unlock_new_inode(inode); |
484 | if (lock_flags) | 475 | if (lock_flags) |
485 | xfs_iunlock(ip, lock_flags); | 476 | xfs_iunlock(ip, lock_flags); |
486 | VN_RELE(vp); | 477 | IRELE(ip); |
487 | } | 478 | } |
488 | 479 | ||
489 | 480 | ||
@@ -496,8 +487,6 @@ xfs_iput_new(xfs_inode_t *ip, | |||
496 | void | 487 | void |
497 | xfs_ireclaim(xfs_inode_t *ip) | 488 | xfs_ireclaim(xfs_inode_t *ip) |
498 | { | 489 | { |
499 | bhv_vnode_t *vp; | ||
500 | |||
501 | /* | 490 | /* |
502 | * Remove from old hash list and mount list. | 491 | * Remove from old hash list and mount list. |
503 | */ | 492 | */ |
@@ -526,9 +515,8 @@ xfs_ireclaim(xfs_inode_t *ip) | |||
526 | /* | 515 | /* |
527 | * Pull our behavior descriptor from the vnode chain. | 516 | * Pull our behavior descriptor from the vnode chain. |
528 | */ | 517 | */ |
529 | vp = XFS_ITOV_NULL(ip); | 518 | if (ip->i_vnode) { |
530 | if (vp) { | 519 | ip->i_vnode->i_private = NULL; |
531 | vn_to_inode(vp)->i_private = NULL; | ||
532 | ip->i_vnode = NULL; | 520 | ip->i_vnode = NULL; |
533 | } | 521 | } |
534 | 522 | ||
diff --git a/fs/xfs/xfs_inode.h b/fs/xfs/xfs_inode.h index 88caadde607..d8ed51e28cb 100644 --- a/fs/xfs/xfs_inode.h +++ b/fs/xfs/xfs_inode.h | |||
@@ -468,7 +468,6 @@ void xfs_ihash_init(struct xfs_mount *); | |||
468 | void xfs_ihash_free(struct xfs_mount *); | 468 | void xfs_ihash_free(struct xfs_mount *); |
469 | xfs_inode_t *xfs_inode_incore(struct xfs_mount *, xfs_ino_t, | 469 | xfs_inode_t *xfs_inode_incore(struct xfs_mount *, xfs_ino_t, |
470 | struct xfs_trans *); | 470 | struct xfs_trans *); |
471 | void xfs_inode_lock_init(xfs_inode_t *, bhv_vnode_t *); | ||
472 | int xfs_iget(struct xfs_mount *, struct xfs_trans *, xfs_ino_t, | 471 | int xfs_iget(struct xfs_mount *, struct xfs_trans *, xfs_ino_t, |
473 | uint, uint, xfs_inode_t **, xfs_daddr_t); | 472 | uint, uint, xfs_inode_t **, xfs_daddr_t); |
474 | void xfs_iput(xfs_inode_t *, uint); | 473 | void xfs_iput(xfs_inode_t *, uint); |