Lines Matching refs:sdp

55 	struct gfs2_sbd *sdp;		/* incore superblock           */  member
157 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in glock_blocked_by_withdraw() local
159 if (likely(!gfs2_withdrawn(sdp))) in glock_blocked_by_withdraw()
163 if (!sdp->sd_jdesc || in glock_blocked_by_withdraw()
164 gl->gl_name.ln_number == sdp->sd_jdesc->jd_no_addr) in glock_blocked_by_withdraw()
171 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in gfs2_glock_free() local
178 if (atomic_dec_and_test(&sdp->sd_glock_disposal)) in gfs2_glock_free()
179 wake_up(&sdp->sd_kill_wait); in gfs2_glock_free()
272 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in __gfs2_glock_put() local
281 if (!gfs2_withdrawn(sdp)) in __gfs2_glock_put()
285 sdp->sd_lockstruct.ls_ops->lm_put_lock(gl); in __gfs2_glock_put()
372 struct gfs2_sbd *sdp = gh->gh_gl->gl_name.ln_sbd; in gfs2_holder_wake() local
374 wake_up(&sdp->sd_async_glock_wait); in gfs2_holder_wake()
549 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in gfs2_set_demote() local
553 wake_up(&sdp->sd_async_glock_wait); in gfs2_set_demote()
653 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in is_system_glock() local
654 struct gfs2_inode *m_ip = GFS2_I(sdp->sd_statfs_inode); in is_system_glock()
675 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in do_xmote() local
712 if (cmpxchg(&sdp->sd_log_error, 0, ret)) { in do_xmote()
713 fs_err(sdp, "Error %d syncing glock \n", ret); in do_xmote()
728 (!cmpxchg(&sdp->sd_log_error, 0, -EIO))) { in do_xmote()
760 if (unlikely(sdp->sd_log_error && !gfs2_withdrawn(sdp))) in do_xmote()
761 gfs2_withdraw_delayed(sdp); in do_xmote()
764 test_bit(SDF_WITHDRAW_RECOVERY, &sdp->sd_flags))) { in do_xmote()
787 if (sdp->sd_lockstruct.ls_ops->lm_lock) { in do_xmote()
789 ret = sdp->sd_lockstruct.ls_ops->lm_lock(gl, target, lck_flags); in do_xmote()
792 test_bit(SDF_SKIP_DLM_UNLOCK, &sdp->sd_flags)) { in do_xmote()
796 fs_err(sdp, "lm_lock ret %d\n", ret); in do_xmote()
797 GLOCK_BUG_ON(gl, !gfs2_withdrawn(sdp)); in do_xmote()
980 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in gfs2_queue_try_to_evict() local
984 return queue_delayed_work(sdp->sd_delete_wq, in gfs2_queue_try_to_evict()
990 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in gfs2_queue_verify_evict() local
994 return queue_delayed_work(sdp->sd_delete_wq, in gfs2_queue_verify_evict()
1002 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in delete_work_func() local
1025 if (test_bit(SDF_KILL, &sdp->sd_flags)) in delete_work_func()
1034 inode = gfs2_lookup_by_inum(sdp, no_addr, gl->gl_no_formal_ino, in delete_work_func()
1038 !test_bit(SDF_KILL, &sdp->sd_flags) && in delete_work_func()
1145 int gfs2_glock_get(struct gfs2_sbd *sdp, u64 number, in gfs2_glock_get() argument
1149 struct super_block *s = sdp->sd_vfs; in gfs2_glock_get()
1152 .ln_sbd = sdp }; in gfs2_glock_get()
1187 atomic_inc(&sdp->sd_glock_disposal); in gfs2_glock_get()
1199 gl->gl_stats = this_cpu_ptr(sdp->sd_lkstats)->lkstats[glops->go_type]; in gfs2_glock_get()
1233 if (atomic_dec_and_test(&sdp->sd_glock_disposal)) in gfs2_glock_get()
1234 wake_up(&sdp->sd_kill_wait); in gfs2_glock_get()
1364 struct gfs2_sbd *sdp = ghs[0].gh_gl->gl_name.ln_sbd; in gfs2_glock_async_wait() local
1376 if (!wait_event_timeout(sdp->sd_async_glock_wait, in gfs2_glock_async_wait()
1479 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in add_to_queue() local
1529 if (sdp->sd_lockstruct.ls_ops->lm_cancel) in add_to_queue()
1530 sdp->sd_lockstruct.ls_ops->lm_cancel(gl); in add_to_queue()
1535 fs_err(sdp, "original: %pSR\n", (void *)gh2->gh_ip); in add_to_queue()
1536 fs_err(sdp, "pid: %d\n", pid_nr(gh2->gh_owner_pid)); in add_to_queue()
1537 fs_err(sdp, "lock type: %d req lock state : %d\n", in add_to_queue()
1539 fs_err(sdp, "new: %pSR\n", (void *)gh->gh_ip); in add_to_queue()
1540 fs_err(sdp, "pid: %d\n", pid_nr(gh->gh_owner_pid)); in add_to_queue()
1541 fs_err(sdp, "lock type: %d req lock state : %d\n", in add_to_queue()
1651 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in gfs2_glock_dq() local
1677 if (test_bit(SDF_WITHDRAW_RECOVERY, &sdp->sd_flags) && in gfs2_glock_dq()
1679 gh->gh_gl != sdp->sd_jinode_gl) { in gfs2_glock_dq()
1680 sdp->sd_glock_dqs_held++; in gfs2_glock_dq()
1683 wait_on_bit(&sdp->sd_flags, SDF_WITHDRAW_RECOVERY, in gfs2_glock_dq()
1725 int gfs2_glock_nq_num(struct gfs2_sbd *sdp, u64 number, in gfs2_glock_nq_num() argument
1732 error = gfs2_glock_get(sdp, number, glops, CREATE, &gl); in gfs2_glock_nq_num()
2060 static void glock_hash_walk(glock_examiner examiner, const struct gfs2_sbd *sdp) in glock_hash_walk() argument
2071 if (gl->gl_name.ln_sbd == sdp) in glock_hash_walk()
2092 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in flush_delete_work() local
2095 queue_delayed_work(sdp->sd_delete_wq, in flush_delete_work()
2101 void gfs2_flush_delete_work(struct gfs2_sbd *sdp) in gfs2_flush_delete_work() argument
2103 glock_hash_walk(flush_delete_work, sdp); in gfs2_flush_delete_work()
2104 flush_workqueue(sdp->sd_delete_wq); in gfs2_flush_delete_work()
2149 void gfs2_glock_thaw(struct gfs2_sbd *sdp) in gfs2_glock_thaw() argument
2151 glock_hash_walk(thaw_glock, sdp); in gfs2_glock_thaw()
2175 void gfs2_gl_dq_holders(struct gfs2_sbd *sdp) in gfs2_gl_dq_holders() argument
2177 glock_hash_walk(withdraw_dq, sdp); in gfs2_gl_dq_holders()
2187 void gfs2_gl_hash_clear(struct gfs2_sbd *sdp) in gfs2_gl_hash_clear() argument
2189 set_bit(SDF_SKIP_DLM_UNLOCK, &sdp->sd_flags); in gfs2_gl_hash_clear()
2191 glock_hash_walk(clear_glock, sdp); in gfs2_gl_hash_clear()
2193 wait_event_timeout(sdp->sd_kill_wait, in gfs2_gl_hash_clear()
2194 atomic_read(&sdp->sd_glock_disposal) == 0, in gfs2_gl_hash_clear()
2196 glock_hash_walk(dump_glock_func, sdp); in gfs2_gl_hash_clear()
2346 struct gfs2_sbd *sdp = gl->gl_name.ln_sbd; in gfs2_dump_glock() local
2347 char fs_id_buf[sizeof(sdp->sd_fsname) + 7]; in gfs2_dump_glock()
2356 if (fsid && sdp) /* safety precaution */ in gfs2_dump_glock()
2357 sprintf(fs_id_buf, "fsid=%s: ", sdp->sd_fsname); in gfs2_dump_glock()
2428 struct gfs2_sbd *sdp = seq->private; in gfs2_sbstats_seq_show() local
2441 const struct gfs2_pcpu_lkstats *lkstats = per_cpu_ptr(sdp->sd_lkstats, i); in gfs2_sbstats_seq_show()
2508 if (gl->gl_name.ln_sbd != gi->sdp) in gfs2_glock_iter_next()
2626 gi->sdp = inode->i_private; in __gfs2_glocks_open()
2826 struct gfs2_sbd *sdp = inode->i_private; in gfs2_glockfd_open() local
2832 i->sb = sdp->sd_vfs; in gfs2_glockfd_open()
2846 void gfs2_create_debugfs_file(struct gfs2_sbd *sdp) in gfs2_create_debugfs_file() argument
2848 sdp->debugfs_dir = debugfs_create_dir(sdp->sd_table_name, gfs2_root); in gfs2_create_debugfs_file()
2850 debugfs_create_file("glocks", S_IFREG | S_IRUGO, sdp->debugfs_dir, sdp, in gfs2_create_debugfs_file()
2853 debugfs_create_file("glockfd", S_IFREG | S_IRUGO, sdp->debugfs_dir, sdp, in gfs2_create_debugfs_file()
2856 debugfs_create_file("glstats", S_IFREG | S_IRUGO, sdp->debugfs_dir, sdp, in gfs2_create_debugfs_file()
2859 debugfs_create_file("sbstats", S_IFREG | S_IRUGO, sdp->debugfs_dir, sdp, in gfs2_create_debugfs_file()
2863 void gfs2_delete_debugfs_file(struct gfs2_sbd *sdp) in gfs2_delete_debugfs_file() argument
2865 debugfs_remove_recursive(sdp->debugfs_dir); in gfs2_delete_debugfs_file()
2866 sdp->debugfs_dir = NULL; in gfs2_delete_debugfs_file()