fid.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. * V9FS FID Management
  3. *
  4. * Copyright (C) 2005 by Eric Van Hensbergen <ericvh@gmail.com>
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2
  8. * as published by the Free Software Foundation.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program; if not, write to:
  17. * Free Software Foundation
  18. * 51 Franklin Street, Fifth Floor
  19. * Boston, MA 02111-1301 USA
  20. *
  21. */
  22. #include <linux/list.h>
  23. /**
  24. * struct v9fs_dentry - 9p private data stored in dentry d_fsdata
  25. * @lock: protects the fidlist
  26. * @fidlist: list of FIDs currently associated with this dentry
  27. *
  28. * This structure defines the 9p private data associated with
  29. * a particular dentry. In particular, this private data is used
  30. * to lookup which 9P FID handle should be used for a particular VFS
  31. * operation. FID handles are associated with dentries instead of
  32. * inodes in order to more closely map functionality to the Plan 9
  33. * expected behavior for FID reclaimation and tracking.
  34. *
  35. * See Also: Mapping FIDs to Linux VFS model in
  36. * Design and Implementation of the Linux 9P File System documentation
  37. */
  38. struct v9fs_dentry {
  39. spinlock_t lock; /* protect fidlist */
  40. struct list_head fidlist;
  41. };
  42. struct p9_fid *v9fs_fid_lookup(struct dentry *dentry);
  43. struct p9_fid *v9fs_fid_clone(struct dentry *dentry);
  44. int v9fs_fid_add(struct dentry *dentry, struct p9_fid *fid);