nfs4filelayout.h 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * NFSv4 file layout driver data structures.
  3. *
  4. * Copyright (c) 2002
  5. * The Regents of the University of Michigan
  6. * All Rights Reserved
  7. *
  8. * Dean Hildebrand <dhildebz@umich.edu>
  9. *
  10. * Permission is granted to use, copy, create derivative works, and
  11. * redistribute this software and such derivative works for any purpose,
  12. * so long as the name of the University of Michigan is not used in
  13. * any advertising or publicity pertaining to the use or distribution
  14. * of this software without specific, written prior authorization. If
  15. * the above copyright notice or any other identification of the
  16. * University of Michigan is included in any copy of any portion of
  17. * this software, then the disclaimer below must also be included.
  18. *
  19. * This software is provided as is, without representation or warranty
  20. * of any kind either express or implied, including without limitation
  21. * the implied warranties of merchantability, fitness for a particular
  22. * purpose, or noninfringement. The Regents of the University of
  23. * Michigan shall not be liable for any damages, including special,
  24. * indirect, incidental, or consequential damages, with respect to any
  25. * claim arising out of or in connection with the use of the software,
  26. * even if it has been or is hereafter advised of the possibility of
  27. * such damages.
  28. */
  29. #ifndef FS_NFS_NFS4FILELAYOUT_H
  30. #define FS_NFS_NFS4FILELAYOUT_H
  31. #include "pnfs.h"
  32. /*
  33. * Field testing shows we need to support upto 4096 stripe indices.
  34. * We store each index as a u8 (u32 on the wire) to keep the memory footprint
  35. * reasonable. This in turn means we support a maximum of 256
  36. * RFC 5661 multipath_list4 structures.
  37. */
  38. #define NFS4_PNFS_MAX_STRIPE_CNT 4096
  39. #define NFS4_PNFS_MAX_MULTI_CNT 256 /* 256 fit into a u8 stripe_index */
  40. enum stripetype4 {
  41. STRIPE_SPARSE = 1,
  42. STRIPE_DENSE = 2
  43. };
  44. /* Individual ip address */
  45. struct nfs4_pnfs_ds {
  46. struct list_head ds_node; /* nfs4_pnfs_dev_hlist dev_dslist */
  47. u32 ds_ip_addr;
  48. u32 ds_port;
  49. struct nfs_client *ds_clp;
  50. atomic_t ds_count;
  51. };
  52. struct nfs4_file_layout_dsaddr {
  53. struct pnfs_deviceid_node deviceid;
  54. u32 stripe_count;
  55. u8 *stripe_indices;
  56. u32 ds_num;
  57. struct nfs4_pnfs_ds *ds_list[1];
  58. };
  59. struct nfs4_filelayout_segment {
  60. struct pnfs_layout_segment generic_hdr;
  61. u32 stripe_type;
  62. u32 commit_through_mds;
  63. u32 stripe_unit;
  64. u32 first_stripe_index;
  65. u64 pattern_offset;
  66. struct nfs4_file_layout_dsaddr *dsaddr; /* Point to GETDEVINFO data */
  67. unsigned int num_fh;
  68. struct nfs_fh **fh_array;
  69. };
  70. static inline struct nfs4_filelayout_segment *
  71. FILELAYOUT_LSEG(struct pnfs_layout_segment *lseg)
  72. {
  73. return container_of(lseg,
  74. struct nfs4_filelayout_segment,
  75. generic_hdr);
  76. }
  77. extern void nfs4_fl_free_deviceid_callback(struct pnfs_deviceid_node *);
  78. extern void print_ds(struct nfs4_pnfs_ds *ds);
  79. extern void print_deviceid(struct nfs4_deviceid *dev_id);
  80. extern struct nfs4_file_layout_dsaddr *
  81. nfs4_fl_find_get_deviceid(struct nfs_client *, struct nfs4_deviceid *dev_id);
  82. struct nfs4_file_layout_dsaddr *
  83. get_device_info(struct inode *inode, struct nfs4_deviceid *dev_id);
  84. #endif /* FS_NFS_NFS4FILELAYOUT_H */