Lines Matching refs:cinfo
62 static void nfs_init_cinfo_from_inode(struct nfs_commit_info *cinfo,
831 struct nfs_commit_info cinfo; in nfs_page_search_commits_for_head_request_locked() local
834 nfs_init_cinfo_from_inode(&cinfo, inode); in nfs_page_search_commits_for_head_request_locked()
837 freq = pnfs_search_commit_reqs(inode, &cinfo, page); in nfs_page_search_commits_for_head_request_locked()
842 list_for_each_entry_safe(freq, t, &cinfo.mds->list, wb_list) { in nfs_page_search_commits_for_head_request_locked()
865 struct nfs_commit_info *cinfo) in nfs_request_add_commit_list_locked() argument
869 atomic_long_inc(&cinfo->mds->ncommit); in nfs_request_add_commit_list_locked()
886 nfs_request_add_commit_list(struct nfs_page *req, struct nfs_commit_info *cinfo) in nfs_request_add_commit_list() argument
888 mutex_lock(&NFS_I(cinfo->inode)->commit_mutex); in nfs_request_add_commit_list()
889 nfs_request_add_commit_list_locked(req, &cinfo->mds->list, cinfo); in nfs_request_add_commit_list()
890 mutex_unlock(&NFS_I(cinfo->inode)->commit_mutex); in nfs_request_add_commit_list()
892 nfs_mark_page_unstable(req->wb_page, cinfo); in nfs_request_add_commit_list()
909 struct nfs_commit_info *cinfo) in nfs_request_remove_commit_list() argument
914 atomic_long_dec(&cinfo->mds->ncommit); in nfs_request_remove_commit_list()
918 static void nfs_init_cinfo_from_inode(struct nfs_commit_info *cinfo, in nfs_init_cinfo_from_inode() argument
921 cinfo->inode = inode; in nfs_init_cinfo_from_inode()
922 cinfo->mds = &NFS_I(inode)->commit_info; in nfs_init_cinfo_from_inode()
923 cinfo->ds = pnfs_get_ds_info(inode); in nfs_init_cinfo_from_inode()
924 cinfo->dreq = NULL; in nfs_init_cinfo_from_inode()
925 cinfo->completion_ops = &nfs_commit_completion_ops; in nfs_init_cinfo_from_inode()
928 void nfs_init_cinfo(struct nfs_commit_info *cinfo, in nfs_init_cinfo() argument
933 nfs_init_cinfo_from_dreq(cinfo, dreq); in nfs_init_cinfo()
935 nfs_init_cinfo_from_inode(cinfo, inode); in nfs_init_cinfo()
944 struct nfs_commit_info *cinfo, u32 ds_commit_idx) in nfs_mark_request_commit() argument
946 if (pnfs_mark_request_commit(req, lseg, cinfo, ds_commit_idx)) in nfs_mark_request_commit()
948 nfs_request_add_commit_list(req, cinfo); in nfs_mark_request_commit()
966 struct nfs_commit_info cinfo; in nfs_clear_request_commit() local
968 nfs_init_cinfo_from_inode(&cinfo, inode); in nfs_clear_request_commit()
970 if (!pnfs_clear_request_commit(req, &cinfo)) { in nfs_clear_request_commit()
971 nfs_request_remove_commit_list(req, &cinfo); in nfs_clear_request_commit()
992 struct nfs_commit_info cinfo; in nfs_write_completion() local
997 nfs_init_cinfo_from_inode(&cinfo, hdr->inode); in nfs_write_completion()
1013 nfs_mark_request_commit(req, hdr->lseg, &cinfo, in nfs_write_completion()
1029 nfs_reqs_to_commit(struct nfs_commit_info *cinfo) in nfs_reqs_to_commit() argument
1031 return atomic_long_read(&cinfo->mds->ncommit); in nfs_reqs_to_commit()
1037 struct nfs_commit_info *cinfo, int max) in nfs_scan_commit_list() argument
1048 nfs_request_remove_commit_list(req, cinfo); in nfs_scan_commit_list()
1052 if ((ret == max) && !cinfo->dreq) in nfs_scan_commit_list()
1071 struct nfs_commit_info *cinfo) in nfs_scan_commit() argument
1075 if (!atomic_long_read(&cinfo->mds->ncommit)) in nfs_scan_commit()
1077 mutex_lock(&NFS_I(cinfo->inode)->commit_mutex); in nfs_scan_commit()
1078 if (atomic_long_read(&cinfo->mds->ncommit) > 0) { in nfs_scan_commit()
1081 ret = nfs_scan_commit_list(&cinfo->mds->list, dst, in nfs_scan_commit()
1082 cinfo, max); in nfs_scan_commit()
1083 ret += pnfs_scan_commit_lists(inode, cinfo, max - ret); in nfs_scan_commit()
1085 mutex_unlock(&NFS_I(cinfo->inode)->commit_mutex); in nfs_scan_commit()
1663 static int wait_on_commit(struct nfs_mds_commit_info *cinfo) in wait_on_commit() argument
1665 return wait_var_event_killable(&cinfo->rpcs_out, in wait_on_commit()
1666 !atomic_read(&cinfo->rpcs_out)); in wait_on_commit()
1669 static void nfs_commit_begin(struct nfs_mds_commit_info *cinfo) in nfs_commit_begin() argument
1671 atomic_inc(&cinfo->rpcs_out); in nfs_commit_begin()
1674 bool nfs_commit_end(struct nfs_mds_commit_info *cinfo) in nfs_commit_end() argument
1676 if (atomic_dec_and_test(&cinfo->rpcs_out)) { in nfs_commit_end()
1677 wake_up_var(&cinfo->rpcs_out); in nfs_commit_end()
1746 struct nfs_commit_info *cinfo) in nfs_init_commit() argument
1769 data->completion_ops = cinfo->completion_ops; in nfs_init_commit()
1770 data->dreq = cinfo->dreq; in nfs_init_commit()
1780 nfs_commit_begin(cinfo->mds); in nfs_init_commit()
1786 struct nfs_commit_info *cinfo, in nfs_retry_commit() argument
1794 nfs_mark_request_commit(req, lseg, cinfo, ds_commit_idx); in nfs_retry_commit()
1795 if (!cinfo->dreq) in nfs_retry_commit()
1803 nfs_commit_resched_write(struct nfs_commit_info *cinfo, in nfs_commit_resched_write() argument
1814 struct nfs_commit_info *cinfo) in nfs_commit_list() argument
1826 nfs_init_commit(data, head, NULL, cinfo); in nfs_commit_list()
1851 struct nfs_commit_info cinfo; in nfs_commit_release_pages() local
1897 nfs_init_cinfo(&cinfo, data->inode, data->dreq); in nfs_commit_release_pages()
1898 nfs_commit_end(cinfo.mds); in nfs_commit_release_pages()
1921 int how, struct nfs_commit_info *cinfo) in nfs_generic_commit_list() argument
1925 status = pnfs_commit_list(inode, head, how, cinfo); in nfs_generic_commit_list()
1927 status = nfs_commit_list(inode, head, how, cinfo); in nfs_generic_commit_list()
1935 struct nfs_commit_info cinfo; in __nfs_commit_inode() local
1940 nfs_init_cinfo_from_inode(&cinfo, inode); in __nfs_commit_inode()
1941 nfs_commit_begin(cinfo.mds); in __nfs_commit_inode()
1943 ret = nscan = nfs_scan_commit(inode, &head, &cinfo); in __nfs_commit_inode()
1946 ret = nfs_generic_commit_list(inode, &head, how, &cinfo); in __nfs_commit_inode()
1960 nfs_commit_end(cinfo.mds); in __nfs_commit_inode()
1963 return wait_on_commit(cinfo.mds); in __nfs_commit_inode()