959d91ba65777c386963adaa592b6d1a1b8e4591
[openafs.git] / src / config / afs_args.h
1 /*
2  * Copyright 2000, International Business Machines Corporation and others.
3  * All Rights Reserved.
4  *
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
8  */
9
10 /*
11  * AFS system call opcodes
12  */
13
14 #ifndef _AFS_ARGS_H_
15 #define _AFS_ARGS_H_
16
17 #define AFSOP_START_RXCALLBACK    0     /* no aux parms */
18 #define AFSOP_START_AFS           1     /* no aux parms */
19 #define AFSOP_START_BKG           2     /* no aux parms */
20 #define AFSOP_START_TRUNCDAEMON   3     /* no aux parms */
21 #define AFSOP_START_CS            4     /* no aux parms */
22
23 #define AFSOP_ADDCELL             5     /* parm 2 = cell str */
24 #define AFSOP_CACHEINIT           6     /* parms 2-4 -> cache sizes */
25 #define AFSOP_CACHEINFO           7     /* the cacheinfo file */
26 #define AFSOP_VOLUMEINFO          8     /* the volumeinfo file */
27 #define AFSOP_CACHEFILE           9     /* a random cache file (V*) */
28 #define AFSOP_CACHEINODE         10     /* random cache file by inode */
29 #define AFSOP_AFSLOG             11     /* output log file */
30 #define AFSOP_ROOTVOLUME         12     /* non-standard root volume name */
31 #define AFSOP_STARTLOG           14     /* temporary: Start afs logging */
32 #define AFSOP_ENDLOG             15     /* temporary: End afs logging */
33 #define AFSOP_AFS_VFSMOUNT       16     /* vfsmount cover for hpux */
34 #define AFSOP_ADVISEADDR         17     /* to init rx cid generator */
35 #define AFSOP_CLOSEWAIT          18     /* make all closes synchronous */
36 #define AFSOP_RXEVENT_DAEMON     19     /* rxevent daemon */
37 #define AFSOP_GETMTU             20     /* stand-in for SIOCGIFMTU, for now */
38 #define AFSOP_GETIFADDRS         21     /* get machine's ethernet interfaces */
39
40 #define AFSOP_ADDCELL2           29     /* 2nd add cell protocol interface */
41 #define AFSOP_AFSDB_HANDLER      30     /* userspace AFSDB lookup handler */
42 #define AFSOP_SET_DYNROOT        31     /* enable/disable dynroot support */
43 #define AFSOP_ADDCELLALIAS       32     /* create alias for existing cell */
44 #define AFSOP_SET_FAKESTAT       33     /* enable/disable fakestat support */
45 #define AFSOP_CELLINFO           34     /* set the cellinfo file name */
46 #define AFSOP_SET_THISCELL       35     /* set the primary cell */
47 #define AFSOP_BASIC_INIT         36     /* used to be part of START_AFS */
48 #define AFSOP_SET_BACKUPTREE     37     /* enable backup tree support */
49 #define AFSOP_SET_RXPCK          38     /* set rx_extraPackets*/
50 #define AFSOP_BUCKETPCT          39     /* bucket percentage */
51 #define AFSOP_SET_RXMAXMTU       40     /* set rx_MyMaxSendSize,rx_maxReceiveSizeUser,rx_maxReceiveSize */
52 #define AFSOP_BKG_HANDLER        41     /* userspace-capable Bkg daemon */
53 #define AFSOP_SET_RXMAXFRAGS     43     /* set rxi_nSendFrags, rxi_nRecvFrags */
54 #define AFSOP_SET_RMTSYS_FLAG    44     /* set flag if rmtsys is enabled */
55 #define AFSOP_SEED_ENTROPY       45     /* Give the kernel hcrypto entropy */
56 #define AFSOP_SET_INUMCALC       46     /* set inode number calculation method */
57
58 /* The range 20-30 is reserved for AFS system offsets in the afs_syscall */
59 #define AFSCALL_PIOCTL          20
60 #define AFSCALL_SETPAG          21
61 #define AFSCALL_IOPEN           22
62 #define AFSCALL_ICREATE         23
63 #define AFSCALL_IREAD           24
64 #define AFSCALL_IWRITE          25
65 #define AFSCALL_IINC            26
66 #define AFSCALL_IDEC            27
67 #define AFSCALL_CALL            28
68
69 #define AFSCALL_ICL             30
70
71 /* 64 bit versions of inode system calls. */
72 #define AFSCALL_IOPEN64         41
73 #define AFSCALL_ICREATE64       42
74 #define AFSCALL_IINC64          43
75 #define AFSCALL_IDEC64          44
76 #define AFSCALL_ILISTINODE64    45      /* Used by ListViceInodes */
77 #define AFSCALL_ICREATENAME64   46      /* pass in platform specific pointer
78                                          * used to create a name in in a
79                                          * directory.
80                                          */
81 #ifdef AFS_SGI_VNODE_GLUE
82 #define AFSCALL_INIT_KERNEL_CONFIG 47   /* set vnode glue ops. */
83 #endif
84
85 #define AFSOP_GETMASK            42     /* stand-in for SIOCGIFNETMASK */
86 /* For SGI, this can't interfere with any of the 64 bit inode calls. */
87 #define AFSOP_RXLISTENER_DAEMON  48     /* starts kernel RX listener */
88
89 /* skip 64 bit calls */
90 #define AFSOP_CACHEBASEDIR       50     /* cache base dir */
91 #define AFSOP_CACHEDIRS          51     /* number of files per dir */
92 #define AFSOP_CACHEFILES         52     /* number of files */
93
94 #define AFSOP_SETINT             60     /* we should just set key/value pairs
95                                           for things which are just ints */
96
97 /* these are for initialization flags */
98
99 #define AFSCALL_INIT_MEMCACHE 0x1
100
101 /* flags for rxstats pioctl */
102
103 #define AFSCALL_RXSTATS_MASK    0x7     /* Valid flag bits */
104 #define AFSCALL_RXSTATS_ENABLE  0x1     /* Enable RX stats */
105 #define AFSCALL_RXSTATS_DISABLE 0x2     /* Disable RX stats */
106 #define AFSCALL_RXSTATS_CLEAR   0x4     /* Clear RX stats */
107
108 #define AFSOP_GO                100     /* whether settime is being done */
109 /* not for initialization: debugging assist */
110 #define AFSOP_CHECKLOCKS        200     /* dump lock state */
111 #define AFSOP_SHUTDOWN          201     /* Totally shutdown afs (deallocate all) */
112
113 /* The following aren't used by afs_initState but by afs_termState! */
114 #define AFSOP_STOP_RXCALLBACK   210     /* Stop CALLBACK process */
115 #define AFSOP_STOP_AFS          211     /* Stop AFS process */
116 #define AFSOP_STOP_CS           216     /* Stop CheckServer daemon. */
117 #define AFSOP_STOP_BKG          212     /* Stop BKG process */
118 #define AFSOP_STOP_TRUNCDAEMON  213     /* Stop cache truncate daemon */
119 /* #define AFSOP_STOP_RXEVENT   214     defined in osi.h              */
120 /* #define AFSOP_STOP_COMPLETE     215  defined in osi.h              */
121 /* #define AFSOP_STOP_RXK_LISTENER   217     defined in osi.h         */
122 #define AFSOP_STOP_AFSDB        218     /* Stop AFSDB handler */
123 #define AFSOP_STOP_NETIF        219     /* Stop Netif poller */
124
125 /* Main afs syscall entry; this number may vary per system (i.e. defined in afs/param.h) */
126 #ifndef AFS_SYSCALL
127 #define AFS_SYSCALL             31
128 #endif
129
130 /* arguments passed by afsd */
131 #define IDTYPE_UID 0
132
133 /* We don't necessarily have VenusFid here */
134 struct afs_umv_param {
135     afs_int32 id;
136     afs_int32 idtype;
137     afs_int32 sCell;
138     afs_int32 sVolume;
139     afs_int32 sVnode;
140     afs_int32 sUnique;
141     afs_int32 dCell;
142     afs_int32 dVolume;
143     afs_int32 dVnode;
144     afs_int32 dUnique;
145 };
146
147 #define AFS_USPC_UMV 1
148
149 struct afs_uspc_param {
150     afs_int32 retval;
151     afs_int32 ts; /* brequest ts - always unique */
152     afs_int32 bufSz;
153     afs_int32 reqtype;
154     union {
155         struct afs_umv_param umv;
156     } req;
157 };
158
159 struct afs_cacheParams {
160     afs_int32 cacheScaches;
161     afs_int32 cacheFiles;
162     afs_int32 cacheBlocks;
163     afs_int32 cacheDcaches;
164     afs_int32 cacheVolumes;
165     afs_int32 chunkSize;
166     afs_int32 setTimeFlag;
167     afs_int32 memCacheFlag;
168     afs_int32 inodes;
169     afs_int32 users;
170     afs_int32 dynamic_vcaches;
171 };
172
173 /* Supported values for AFSOP_SET_INUMCALC. */
174 enum {
175     AFS_INUMCALC_COMPAT = 0,
176     AFS_INUMCALC_MD5 = 1
177 };
178
179
180 /*
181  * Note that the AFS_*ALLOCSIZ values should be multiples of sizeof(void*) to
182  * accomodate pointer alignment.
183  */
184 /* Used in rx.c as well as afs directory. */
185 #if     defined(AFS_AIX32_ENV) || defined(AFS_HPUX_ENV)
186 /* XXX Because of rxkad_cprivate... XXX */
187 #define AFS_SMALLOCSIZ  (38*sizeof(void *))     /* "Small" allocated size */
188 #else
189 #define AFS_SMALLOCSIZ  (64*sizeof(void *))     /*  "Small" allocated size */
190 #endif
191 #define AFS_LRALLOCSIZ  4096    /* "Large" allocated size */
192
193 /* Cache configuration available through the client callback interface */
194 typedef struct cm_initparams_v1 {
195     afs_uint32 nChunkFiles;
196     afs_uint32 nStatCaches;
197     afs_uint32 nDataCaches;
198     afs_uint32 nVolumeCaches;
199     afs_uint32 firstChunkSize;
200     afs_uint32 otherChunkSize;
201     afs_uint32 cacheSize;
202     afs_uint32 setTime;
203     afs_uint32 memCache;
204 } cm_initparams_v1;
205
206 /*
207  * If you need to change afs_cacheParams, you should probably create a brand
208  * new structure.  Keeping the old structure will allow backwards compatibility
209  * with old clients (even if it is only used to calculate allocation size).
210  * If you do change the size or the format, you'll need to bump
211  * AFS_CLIENT_CONFIG_RETRIEVAL_VERSION.  This allows some primitive form
212  * of versioning a la rxdebug.
213  */
214
215 #define AFS_CLIENT_RETRIEVAL_VERSION            1       /* latest version */
216 #define AFS_CLIENT_RETRIEVAL_FIRST_EDITION      1       /* first version */
217
218 /* Defines and structures for the AFS proc replacement layer for the original syscall (AFS_SYSCALL) strategy */
219
220 #ifdef AFS_LINUX20_ENV
221
222 #define PROC_FSDIRNAME "openafs"
223 #define PROC_SYSCALL_NAME "afs_ioctl"
224 #define PROC_SYSCALL_FNAME "/proc/fs/openafs/afs_ioctl"
225 #define PROC_SYSCALL_ARLA_FNAME "/proc/fs/nnpfs/afs_ioctl"
226 #define PROC_CELLSERVDB_NAME "CellServDB"
227 #define PROC_PEER_NAME "rx_peer"
228 #define PROC_CONN_NAME "rx_conn"
229 #define PROC_CALL_NAME "rx_call"
230 #define PROC_RX_NAME "rx"
231 #define PROC_SERVICES_NAME "rx_services"
232 #define PROC_RXSTATS_NAME "rx_stats"
233 #define VIOC_SYSCALL_TYPE 'C'
234 #define VIOC_SYSCALL _IOW(VIOC_SYSCALL_TYPE,1,void *)
235 #define VIOC_SYSCALL32 _IOW(VIOC_SYSCALL_TYPE,1,int)
236
237 struct afsprocdata {
238   long param4;
239   long param3;
240   long param2;
241   long param1;
242   long syscall;
243 };
244
245 struct afsprocdata32 {
246   unsigned int param4;
247   unsigned int param3;
248   unsigned int param2;
249   unsigned int param1;
250   unsigned int syscall;
251 };
252
253 #endif
254
255 #ifdef AFS_DARWIN80_ENV
256 struct afssysargs {
257     unsigned int syscall;
258     unsigned int param1;
259     unsigned int param2;
260     unsigned int param3;
261     unsigned int param4;
262     unsigned int param5;
263     unsigned int param6;
264     unsigned int retval;
265 };
266
267 /* args reordered to avoid alignment issues */
268 struct afssysargs64 {
269     user_addr_t param1;
270     user_addr_t param2;
271     user_addr_t param3;
272     user_addr_t param4;
273     user_addr_t param5;
274     user_addr_t param6;
275     unsigned int syscall;
276     unsigned int retval;
277 };
278 #define VIOC_SYSCALL_TYPE 'C'
279 #define VIOC_SYSCALL _IOWR(VIOC_SYSCALL_TYPE,1,struct afssysargs)
280 #define VIOC_SYSCALL64 _IOWR(VIOC_SYSCALL_TYPE,2,struct afssysargs64)
281 #define SYSCALL_DEV_FNAME "/dev/openafs_ioctl"
282 #endif
283
284 #ifdef AFS_SUN511_ENV
285 # define VIOC_SYSCALL_TYPE 'C'
286 # define VIOC_SYSCALL _IOW(VIOC_SYSCALL_TYPE, 1, struct afssysargs)
287 # define VIOC_SYSCALL32 _IOW(VIOC_SYSCALL_TYPE, 2, struct afssysargs32)
288 # define SYSCALL_DEV_FNAME "/dev/afs"
289
290 struct afssysargs {
291     afs_uint64 param6;
292     afs_uint64 param5;
293     afs_uint64 param4;
294     afs_uint64 param3;
295     afs_uint64 param2;
296     afs_uint64 param1;
297     afs_uint32 syscall;
298 };
299
300 struct afssysargs32 {
301     afs_uint32 param6;
302     afs_uint32 param5;
303     afs_uint32 param4;
304     afs_uint32 param3;
305     afs_uint32 param2;
306     afs_uint32 param1;
307     afs_uint32 syscall;
308 };
309 #endif /* AFS_SUN511_ENV */
310
311 #ifdef AFS_CACHE_VNODE_PATH
312 #define AFS_CACHE_CELLS_INODE -2
313 #define AFS_CACHE_ITEMS_INODE -3
314 #define AFS_CACHE_VOLUME_INODE -4
315 #endif
316
317 #endif /* _AFS_ARGS_H_ */