2 * Copyright 2000, International Business Machines Corporation and others.
5 * This software has been released under the terms of the IBM Public
6 * License. For details, see the LICENSE file in the top-level source
7 * directory or online at http://www.openafs.org/dl/license10.html
13 * Instituition: ITC, CMU
21 #define VOLCREATEVOLUME 100
22 #define VOLDELETEVOLUME 101
23 #define VOLRESTORE 102
24 #define VOLFORWARD 103
25 #define VOLENDTRANS 104
27 #define VOLSETFLAGS 106
28 #define VOLGETFLAGS 107
29 #define VOLTRANSCREATE 108
31 #define VOLGETNTHVOLUME 110
32 #define VOLSETFORWARDING 111 /* defunct */
33 #define VOLGETNAME 112
34 #define VOLGETSTATUS 113
35 #define VOLSIGRESTORE 114
36 #define VOLLISTPARTITIONS 115
37 #define VOLLISTVOLS 116
38 #define VOLSETIDSTYPES 117
39 #define VOLMONITOR 118
40 #define VOLDISKPART 119
41 #define VOLRECLONE 120
42 #define VOLLISTONEVOL 121
44 #define VOLSETDATE 123
45 #define VOLXLISTVOLS 124
46 #define VOLXLISTONEVOL 125
47 #define VOLSETINFO 126
48 #define VOLXLISTPARTITIONS 127
49 #define VOLFORWARDMULTIPLE 128
50 #define VOLCONVERTRO 65536
51 #define VOLGETSIZE 65537
52 #define VOLDUMPV2 65538
54 /* Bits for flags for DumpV2 */
55 %#define VOLDUMPV2_OMITDIRS 1
59 struct volser_status {
60 afs_int32 volID; /* Volume id--unique over all systems */
61 afs_int32 nextUnique; /* Next vnode uniquifier for this volume */
62 int type; /* readwrite, etc. */
63 afs_int32 parentID; /* Id of parent, if type==readonly or backup */
64 afs_int32 cloneID; /* Latest read-only clone, if type==readwrite */
65 afs_int32 backupID; /* Latest backup copy of this read write volume */
66 afs_int32 restoredFromID; /* The id in a dump this volume was restored from--used simply
67 to make sure that an incremental dump is not restored on top
68 of something inappropriate: Note: this field itself is NEVER
70 afs_int32 maxQuota; /* Quota maximum, 1K blocks */
71 afs_int32 minQuota; /* Quota minimum, 1K blocks */
72 afs_int32 owner; /* The person responsible for this volume */
73 afs_int32 creationDate; /* Creation date for a read/write
74 volume; cloning date for original copy of
75 a readonly volume (replicated volumes have
76 the same creation date) */
77 afs_int32 accessDate; /* Last access time by a user, large granularity */
78 afs_int32 updateDate; /* Last modification by user */
79 afs_int32 expirationDate; /* 0 if it never expires */
80 afs_int32 backupDate; /* last time a backup clone was taken */
81 afs_int32 copyDate; /* Time that this copy of this volume was created */
94 afs_int32 volid; /* volume's id */
95 afs_int32 type; /* read-only, read-write, backup */
102 unsigned char needsSalvaged;
103 unsigned char destroyMe;
104 afs_int32 creationDate;
105 afs_int32 accessDate;
106 afs_int32 updateDate;
107 afs_int32 backupDate;
112 afs_int32 flags; /* used by the backup system */
113 afs_int32 spare0; /* Used to hold the minquota value */
114 afs_int32 spare1; /* Used to hold the weekuse value */
115 afs_int32 spare2; /* Used to hold volUpdateCounter */
120 * Define some values needed for the detailed volume info structure.
122 const VOLINT_STATS_NUM_RWINFO_FIELDS = 4;
124 const VOLINT_STATS_SAME_NET = 0; /*Within same site (total)*/
125 const VOLINT_STATS_SAME_NET_AUTH = 1; /*Within same site (authenticated);
126 (must be 1 more than above)*/
127 const VOLINT_STATS_DIFF_NET = 2; /*From external site (total)*/
128 const VOLINT_STATS_DIFF_NET_AUTH = 3; /*From external site (authenticated)
129 (must be 1 more than above)*/
131 const VOLINT_STATS_NUM_TIME_RANGES = 6;
133 const VOLINT_STATS_TIME_CAP_0 = 60; /*60 seconds*/
134 const VOLINT_STATS_TIME_CAP_1 = 600; /*10 minutes, in seconds*/
135 const VOLINT_STATS_TIME_CAP_2 = 3600; /*1 hour, in seconds*/
136 const VOLINT_STATS_TIME_CAP_3 = 86400; /*1 day, in seconds*/
137 const VOLINT_STATS_TIME_CAP_4 = 604800; /*1 week, in seconds*/
139 const VOLINT_STATS_NUM_TIME_FIELDS = 6;
141 const VOLINT_STATS_TIME_IDX_0 = 0; /*0 secs to 60 secs*/
142 const VOLINT_STATS_TIME_IDX_1 = 1; /*1 min to 10 mins*/
143 const VOLINT_STATS_TIME_IDX_2 = 2; /*10 mins to 60 mins*/
144 const VOLINT_STATS_TIME_IDX_3 = 3; /*1 hr to 24 hrs*/
145 const VOLINT_STATS_TIME_IDX_4 = 4; /*1 day to 7 days*/
146 const VOLINT_STATS_TIME_IDX_5 = 5; /*Greater than 1 week*/
149 * More detailed volume info
152 char name[VNAMESIZE];
153 afs_int32 volid; /*Volume's ID*/
154 afs_int32 type; /*RWVOL, ROVOL, BACKVOL*/
155 afs_int32 backupID; /*Backup volume ID*/
156 afs_int32 parentID; /*Parent volume ID*/
157 afs_int32 cloneID; /*Clone volume ID*/
158 afs_int32 status; /*Volume status*/
159 afs_int32 copyDate; /*Date when this volume INSTANCE created*/
160 unsigned char inUse; /*In use at time of last crash?*/
161 afs_int32 creationDate; /*Date when this volume was created*/
162 afs_int32 accessDate; /*Date when this volume was last accessed*/
163 afs_int32 updateDate; /*Date when this volume was last updated*/
164 afs_int32 backupDate; /*Date when this volume was last backed up*/
165 int dayUse; /*Number of accesses since midnight*/
166 int filecount; /*Number of files in the volume*/
167 int maxquota; /*Max volume quota, in Kbytes*/
168 int size; /*Current size in Kbytes*/
170 * Detailed statistics for reads/writes and authorship.
172 afs_int32 stat_reads[VOLINT_STATS_NUM_RWINFO_FIELDS];
173 afs_int32 stat_writes[VOLINT_STATS_NUM_RWINFO_FIELDS];
174 afs_int32 stat_fileSameAuthor[VOLINT_STATS_NUM_TIME_FIELDS];
175 afs_int32 stat_fileDiffAuthor[VOLINT_STATS_NUM_TIME_FIELDS];
176 afs_int32 stat_dirSameAuthor[VOLINT_STATS_NUM_TIME_FIELDS];
177 afs_int32 stat_dirDiffAuthor[VOLINT_STATS_NUM_TIME_FIELDS];
180 struct transDebugInfo {
181 afs_int32 tid; /*transaction id */
182 afs_int32 time; /* time transaction was last active (for timeouts) */
183 afs_int32 creationTime; /* time the transaction started */
184 afs_int32 returnCode; /* transaction error code */
185 afs_int32 volid; /*sequence number of the next packet to be read*/ /* open volume's id */
186 afs_int32 partition; /* open volume's partition */
187 short iflags; /* initial attach mode flags (IT*) */
188 char vflags; /* current volume status flags (VT*) */
189 char tflags; /* transaction flags (TT*) */
190 char lastProcName[30]; /* name of the last procedure which used transaction */
191 int callValid; /*flag which determines if following data is valid*/
192 afs_int32 readNext; /*sequence number of the next packet to be read*/
193 afs_int32 transmitNext; /*sequence number of the next packet to be transmitted*/
199 afs_int32 partIds[26];
202 struct diskPartition {
203 char name[32]; /* Mounted partition name */
212 struct restoreCookie {
221 struct destServer server;
224 /* Various size parameters of the volume */
226 afs_uint64 dump_size;
229 typedef replica manyDests<>;
230 typedef afs_int32 manyResults<>;
231 typedef transDebugInfo transDebugEntries<>;
232 typedef volintInfo volEntries<>;
233 typedef afs_int32 partEntries<>;
234 typedef volintXInfo volXEntries<>;
237 IN afs_int32 partition,
241 INOUT afs_int32 *volid,
250 IN afs_int32 toTrans,
252 IN struct restoreCookie *cookie
253 ) split = VOLRESTORE;
256 IN afs_int32 fromTrans,
257 IN afs_int32 fromDate,
258 IN struct destServer *destination,
259 IN afs_int32 destTrans,
260 IN struct restoreCookie *cookie
270 IN afs_int32 purgeVol,
271 IN afs_int32 newType,
273 INOUT afs_int32 *newVol
288 IN afs_int32 partition,
294 IN afs_int32 fromTrans,
295 IN afs_int32 fromDate
300 OUT afs_int32 *volume,
301 OUT afs_int32 *partition
307 ) = VOLSETFORWARDING;
311 OUT string tname<256>
316 OUT struct volser_status *status
327 OUT struct pIDs *partIDs
328 ) = VOLLISTPARTITIONS;
333 OUT volEntries *resultEntries
346 OUT transDebugEntries *result
351 OUT struct diskPartition *partition
362 OUT volEntries *resultEntries
378 OUT volXEntries *resultXEntriesP
384 OUT volXEntries *resultXEntries
389 struct volintInfo *status
392 proc XListPartitions(
393 OUT struct partEntries *partIDs
394 ) = VOLXLISTPARTITIONS;
396 proc ForwardMultiple(
397 IN afs_int32 fromTrans,
398 IN afs_int32 fromDate,
399 IN manyDests *destinations,
401 IN struct restoreCookie *cookie,
402 OUT manyResults *results
403 ) = VOLFORWARDMULTIPLE;
405 proc ConvertROtoRWvolume(
411 IN afs_int32 fromTrans,
412 IN afs_int32 fromDate,
413 OUT struct volintSize *size
417 IN afs_int32 fromTrans,
418 IN afs_int32 fromDate,