Lines Matching refs:file

46 static inline void nlm_debug_print_file(char *msg, struct nlm_file *file)  in nlm_debug_print_file()  argument
48 struct inode *inode = nlmsvc_file_inode(file); in nlm_debug_print_file()
59 static inline void nlm_debug_print_file(char *msg, struct nlm_file *file) in nlm_debug_print_file() argument
87 struct nlm_file *file, int mode) in nlm_do_fopen() argument
89 struct file **fp = &file->f_file[mode]; in nlm_do_fopen()
94 nfserr = nlmsvc_ops->fopen(rqstp, &file->f_handle, fp, mode); in nlm_do_fopen()
108 struct nlm_file *file; in nlm_lookup_file() local
121 hlist_for_each_entry(file, &nlm_files[hash], f_list) in nlm_lookup_file()
122 if (!nfs_compare_fh(&file->f_handle, &lock->fh)) { in nlm_lookup_file()
123 mutex_lock(&file->f_mutex); in nlm_lookup_file()
124 nfserr = nlm_do_fopen(rqstp, file, mode); in nlm_lookup_file()
125 mutex_unlock(&file->f_mutex); in nlm_lookup_file()
131 file = kzalloc(sizeof(*file), GFP_KERNEL); in nlm_lookup_file()
132 if (!file) in nlm_lookup_file()
135 memcpy(&file->f_handle, &lock->fh, sizeof(struct nfs_fh)); in nlm_lookup_file()
136 mutex_init(&file->f_mutex); in nlm_lookup_file()
137 INIT_HLIST_NODE(&file->f_list); in nlm_lookup_file()
138 INIT_LIST_HEAD(&file->f_blocks); in nlm_lookup_file()
140 nfserr = nlm_do_fopen(rqstp, file, mode); in nlm_lookup_file()
144 hlist_add_head(&file->f_list, &nlm_files[hash]); in nlm_lookup_file()
147 dprintk("lockd: found file %p (count %d)\n", file, file->f_count); in nlm_lookup_file()
148 *result = file; in nlm_lookup_file()
149 file->f_count++; in nlm_lookup_file()
156 kfree(file); in nlm_lookup_file()
164 nlm_delete_file(struct nlm_file *file) in nlm_delete_file() argument
166 nlm_debug_print_file("closing file", file); in nlm_delete_file()
167 if (!hlist_unhashed(&file->f_list)) { in nlm_delete_file()
168 hlist_del(&file->f_list); in nlm_delete_file()
169 if (file->f_file[O_RDONLY]) in nlm_delete_file()
170 nlmsvc_ops->fclose(file->f_file[O_RDONLY]); in nlm_delete_file()
171 if (file->f_file[O_WRONLY]) in nlm_delete_file()
172 nlmsvc_ops->fclose(file->f_file[O_WRONLY]); in nlm_delete_file()
173 kfree(file); in nlm_delete_file()
179 static int nlm_unlock_files(struct nlm_file *file, const struct file_lock *fl) in nlm_unlock_files() argument
191 lock.fl_file = file->f_file[O_RDONLY]; in nlm_unlock_files()
194 lock.fl_file = file->f_file[O_WRONLY]; in nlm_unlock_files()
208 nlm_traverse_locks(struct nlm_host *host, struct nlm_file *file, in nlm_traverse_locks() argument
211 struct inode *inode = nlmsvc_file_inode(file); in nlm_traverse_locks()
219 file->f_locks = 0; in nlm_traverse_locks()
226 file->f_locks++; in nlm_traverse_locks()
232 if (nlm_unlock_files(file, fl)) in nlm_traverse_locks()
252 nlm_inspect_file(struct nlm_host *host, struct nlm_file *file, nlm_host_match_fn_t match) in nlm_inspect_file() argument
254 nlmsvc_traverse_blocks(host, file, match); in nlm_inspect_file()
255 nlmsvc_traverse_shares(host, file, match); in nlm_inspect_file()
256 return nlm_traverse_locks(host, file, match); in nlm_inspect_file()
264 nlm_file_inuse(struct nlm_file *file) in nlm_file_inuse() argument
266 struct inode *inode = nlmsvc_file_inode(file); in nlm_file_inuse()
270 if (file->f_count || !list_empty(&file->f_blocks) || file->f_shares) in nlm_file_inuse()
283 file->f_locks = 0; in nlm_file_inuse()
287 static void nlm_close_files(struct nlm_file *file) in nlm_close_files() argument
289 if (file->f_file[O_RDONLY]) in nlm_close_files()
290 nlmsvc_ops->fclose(file->f_file[O_RDONLY]); in nlm_close_files()
291 if (file->f_file[O_WRONLY]) in nlm_close_files()
292 nlmsvc_ops->fclose(file->f_file[O_WRONLY]); in nlm_close_files()
300 int (*is_failover_file)(void *data, struct nlm_file *file)) in nlm_traverse_files() argument
303 struct nlm_file *file; in nlm_traverse_files() local
308 hlist_for_each_entry_safe(file, next, &nlm_files[i], f_list) { in nlm_traverse_files()
309 if (is_failover_file && !is_failover_file(data, file)) in nlm_traverse_files()
311 file->f_count++; in nlm_traverse_files()
316 if (nlm_inspect_file(data, file, match)) in nlm_traverse_files()
320 file->f_count--; in nlm_traverse_files()
322 if (list_empty(&file->f_blocks) && !file->f_locks in nlm_traverse_files()
323 && !file->f_shares && !file->f_count) { in nlm_traverse_files()
324 hlist_del(&file->f_list); in nlm_traverse_files()
325 nlm_close_files(file); in nlm_traverse_files()
326 kfree(file); in nlm_traverse_files()
344 nlm_release_file(struct nlm_file *file) in nlm_release_file() argument
347 file, file->f_count); in nlm_release_file()
353 if (--file->f_count == 0 && !nlm_file_inuse(file)) in nlm_release_file()
354 nlm_delete_file(file); in nlm_release_file()
461 nlmsvc_match_sb(void *datap, struct nlm_file *file) in nlmsvc_match_sb() argument
465 return sb == nlmsvc_file_inode(file)->i_sb; in nlmsvc_match_sb()