afs_vl.h 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /* SPDX-License-Identifier: GPL-2.0-or-later */
  2. /* AFS Volume Location Service client interface
  3. *
  4. * Copyright (C) 2002, 2007 Red Hat, Inc. All Rights Reserved.
  5. * Written by David Howells ([email protected])
  6. */
  7. #ifndef AFS_VL_H
  8. #define AFS_VL_H
  9. #include "afs.h"
  10. #define AFS_VL_PORT 7003 /* volume location service port */
  11. #define VL_SERVICE 52 /* RxRPC service ID for the Volume Location service */
  12. #define YFS_VL_SERVICE 2503 /* Service ID for AuriStor upgraded VL service */
  13. enum AFSVL_Operations {
  14. VLGETENTRYBYID = 503, /* AFS Get VLDB entry by ID */
  15. VLGETENTRYBYNAME = 504, /* AFS Get VLDB entry by name */
  16. VLPROBE = 514, /* AFS probe VL service */
  17. VLGETENTRYBYIDU = 526, /* AFS Get VLDB entry by ID (UUID-variant) */
  18. VLGETENTRYBYNAMEU = 527, /* AFS Get VLDB entry by name (UUID-variant) */
  19. VLGETADDRSU = 533, /* AFS Get addrs for fileserver */
  20. YVLGETENDPOINTS = 64002, /* YFS Get endpoints for file/volume server */
  21. YVLGETCELLNAME = 64014, /* YFS Get actual cell name */
  22. VLGETCAPABILITIES = 65537, /* AFS Get server capabilities */
  23. };
  24. enum AFSVL_Errors {
  25. AFSVL_IDEXIST = 363520, /* Volume Id entry exists in vl database */
  26. AFSVL_IO = 363521, /* I/O related error */
  27. AFSVL_NAMEEXIST = 363522, /* Volume name entry exists in vl database */
  28. AFSVL_CREATEFAIL = 363523, /* Internal creation failure */
  29. AFSVL_NOENT = 363524, /* No such entry */
  30. AFSVL_EMPTY = 363525, /* Vl database is empty */
  31. AFSVL_ENTDELETED = 363526, /* Entry is deleted (soft delete) */
  32. AFSVL_BADNAME = 363527, /* Volume name is illegal */
  33. AFSVL_BADINDEX = 363528, /* Index is out of range */
  34. AFSVL_BADVOLTYPE = 363529, /* Bad volume type */
  35. AFSVL_BADSERVER = 363530, /* Illegal server number (out of range) */
  36. AFSVL_BADPARTITION = 363531, /* Bad partition number */
  37. AFSVL_REPSFULL = 363532, /* Run out of space for Replication sites */
  38. AFSVL_NOREPSERVER = 363533, /* No such Replication server site exists */
  39. AFSVL_DUPREPSERVER = 363534, /* Replication site already exists */
  40. AFSVL_RWNOTFOUND = 363535, /* Parent R/W entry not found */
  41. AFSVL_BADREFCOUNT = 363536, /* Illegal Reference Count number */
  42. AFSVL_SIZEEXCEEDED = 363537, /* Vl size for attributes exceeded */
  43. AFSVL_BADENTRY = 363538, /* Bad incoming vl entry */
  44. AFSVL_BADVOLIDBUMP = 363539, /* Illegal max volid increment */
  45. AFSVL_IDALREADYHASHED = 363540, /* RO/BACK id already hashed */
  46. AFSVL_ENTRYLOCKED = 363541, /* Vl entry is already locked */
  47. AFSVL_BADVOLOPER = 363542, /* Bad volume operation code */
  48. AFSVL_BADRELLOCKTYPE = 363543, /* Bad release lock type */
  49. AFSVL_RERELEASE = 363544, /* Status report: last release was aborted */
  50. AFSVL_BADSERVERFLAG = 363545, /* Invalid replication site server flag */
  51. AFSVL_PERM = 363546, /* No permission access */
  52. AFSVL_NOMEM = 363547, /* malloc/realloc failed to alloc enough memory */
  53. };
  54. enum {
  55. YFS_SERVER_INDEX = 0,
  56. YFS_SERVER_UUID = 1,
  57. YFS_SERVER_ENDPOINT = 2,
  58. };
  59. enum {
  60. YFS_ENDPOINT_IPV4 = 0,
  61. YFS_ENDPOINT_IPV6 = 1,
  62. };
  63. #define YFS_MAXENDPOINTS 16
  64. /*
  65. * maps to "struct vldbentry" in vvl-spec.pdf
  66. */
  67. struct afs_vldbentry {
  68. char name[65]; /* name of volume (with NUL char) */
  69. afs_voltype_t type; /* volume type */
  70. unsigned num_servers; /* num servers that hold instances of this vol */
  71. unsigned clone_id; /* cloning ID */
  72. unsigned flags;
  73. #define AFS_VLF_RWEXISTS 0x1000 /* R/W volume exists */
  74. #define AFS_VLF_ROEXISTS 0x2000 /* R/O volume exists */
  75. #define AFS_VLF_BACKEXISTS 0x4000 /* backup volume exists */
  76. afs_volid_t volume_ids[3]; /* volume IDs */
  77. struct {
  78. struct in_addr addr; /* server address */
  79. unsigned partition; /* partition ID on this server */
  80. unsigned flags; /* server specific flags */
  81. #define AFS_VLSF_NEWREPSITE 0x0001 /* Ignore all 'non-new' servers */
  82. #define AFS_VLSF_ROVOL 0x0002 /* this server holds a R/O instance of the volume */
  83. #define AFS_VLSF_RWVOL 0x0004 /* this server holds a R/W instance of the volume */
  84. #define AFS_VLSF_BACKVOL 0x0008 /* this server holds a backup instance of the volume */
  85. #define AFS_VLSF_UUID 0x0010 /* This server is referred to by its UUID */
  86. #define AFS_VLSF_DONTUSE 0x0020 /* This server ref should be ignored */
  87. } servers[8];
  88. };
  89. #define AFS_VLDB_MAXNAMELEN 65
  90. struct afs_ListAddrByAttributes__xdr {
  91. __be32 Mask;
  92. #define AFS_VLADDR_IPADDR 0x1 /* Match by ->ipaddr */
  93. #define AFS_VLADDR_INDEX 0x2 /* Match by ->index */
  94. #define AFS_VLADDR_UUID 0x4 /* Match by ->uuid */
  95. __be32 ipaddr;
  96. __be32 index;
  97. __be32 spare;
  98. struct afs_uuid__xdr uuid;
  99. };
  100. struct afs_uvldbentry__xdr {
  101. __be32 name[AFS_VLDB_MAXNAMELEN];
  102. __be32 nServers;
  103. struct afs_uuid__xdr serverNumber[AFS_NMAXNSERVERS];
  104. __be32 serverUnique[AFS_NMAXNSERVERS];
  105. __be32 serverPartition[AFS_NMAXNSERVERS];
  106. __be32 serverFlags[AFS_NMAXNSERVERS];
  107. __be32 volumeId[AFS_MAXTYPES];
  108. __be32 cloneId;
  109. __be32 flags;
  110. __be32 spares1;
  111. __be32 spares2;
  112. __be32 spares3;
  113. __be32 spares4;
  114. __be32 spares5;
  115. __be32 spares6;
  116. __be32 spares7;
  117. __be32 spares8;
  118. __be32 spares9;
  119. };
  120. struct afs_address_list {
  121. refcount_t usage;
  122. unsigned int version;
  123. unsigned int nr_addrs;
  124. struct sockaddr_rxrpc addrs[];
  125. };
  126. extern void afs_put_address_list(struct afs_address_list *alist);
  127. #endif /* AFS_VL_H */