efcf6226c9fee15310d4578387ef0c05bfd833ac
[openafs.git] / src / afs / afs_prototypes.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 #ifndef _AFS_PROTOTYPES_H_
11 #define _AFS_PROTOTYPES_H_
12
13 /* afs_analyze.c */
14 extern int afs_Analyze(struct afs_conn *aconn, struct rx_connection *rxconn,
15                        afs_int32 acode, struct VenusFid *afid,
16                        struct vrequest *areq,
17                        int op, afs_int32 locktype, struct cell *cellp);
18
19 /* afs_axscache.c */
20 extern afs_rwlock_t afs_xaxs;
21 extern struct axscache *afs_SlowFindAxs(struct axscache **cachep,
22                                         afs_int32 id);
23 extern struct axscache *axs_Alloc(void);
24 extern void afs_RemoveAxs(struct axscache **headp, struct axscache *axsp);
25 extern void afs_FreeAllAxs(struct axscache **headp);
26 extern void shutdown_xscache(void);
27
28 /* afs_buffer.c */
29 extern void DInit(int abuffers);
30 extern void *DRead(struct dcache * fid, int page);
31 extern int DVOffset(void *ap);
32 extern void DZap(struct dcache * fid);
33 extern void DFlush(void);
34 extern void DFlushDCache(struct dcache *);
35 extern void *DNew(struct dcache * fid, int page);
36 extern void shutdown_bufferpackage(void);
37
38 /* afs_call.c */
39 extern int afs_cold_shutdown;
40 extern afs_int32 afs_setTime;
41 extern char afs_rootVolumeName[64];
42 extern void afs_shutdown(void);
43 extern void afs_FlushCBs(void);
44 extern int afs_CheckInit(void);
45 extern void afs_shutdown(void);
46 extern void shutdown_afstest(void);
47 extern int afs_syscall_call(long parm, long parm2, long parm3,
48                             long parm4, long parm5, long parm6);
49 #if defined(AFS_DARWIN100_ENV)
50 extern int afs_syscall64_call(user_addr_t parm, user_addr_t parm2,
51                               user_addr_t parm3, user_addr_t parm4,
52                               user_addr_t parm5, user_addr_t parm6);
53 #endif
54
55
56 /* afs_callback.c */
57 extern afs_int32 afs_allCBs;
58 extern afs_int32 afs_oddCBs;
59 extern afs_int32 afs_evenCBs;
60 extern afs_int32 afs_allZaps;
61 extern afs_int32 afs_oddZaps;
62 extern afs_int32 afs_evenZaps;
63 extern afs_int32 afs_connectBacks;
64 extern unsigned long lastCallBack_vnode;
65 extern unsigned int lastCallBack_dv;
66 extern osi_timeval_t lastCallBack_time;
67 extern struct interfaceAddr afs_cb_interface;
68
69 extern int afs_RXCallBackServer(void);
70 extern int SRXAFSCB_GetCE(struct rx_call *a_call, afs_int32 a_index,
71                           struct AFSDBCacheEntry *a_result);
72 extern int SRXAFSCB_GetCE64(struct rx_call *a_call, afs_int32 a_index,
73                             struct AFSDBCacheEntry64 *a_result);
74 extern int SRXAFSCB_GetLock(struct rx_call *a_call, afs_int32 a_index,
75                             struct AFSDBLock *a_result);
76 extern int SRXAFSCB_CallBack(struct rx_call *a_call,
77                              struct AFSCBFids *a_fids,
78                              struct AFSCBs *a_callbacks);
79 extern int SRXAFSCB_Probe(struct rx_call *a_call);
80 extern int SRXAFSCB_InitCallBackState(struct rx_call *a_call);
81 extern int SRXAFSCB_XStatsVersion(struct rx_call *a_call,
82                                   afs_int32 * a_versionP);
83 extern int SRXAFSCB_GetXStats(struct rx_call *a_call,
84                               afs_int32 a_clientVersionNum,
85                               afs_int32 a_collectionNumber,
86                               afs_int32 * a_srvVersionNumP,
87                               afs_int32 * a_timeP, AFSCB_CollData * a_dataP);
88 extern int afs_RXCallBackServer(void);
89 extern int shutdown_CB(void);
90 extern int SRXAFSCB_InitCallBackState2(struct rx_call *a_call,
91                                        struct interfaceAddr *addr);
92 extern int SRXAFSCB_WhoAreYou(struct rx_call *a_call,
93                               struct interfaceAddr *addr);
94 extern int SRXAFSCB_InitCallBackState3(struct rx_call *a_call,
95                                        afsUUID * a_uuid);
96 extern int SRXAFSCB_ProbeUuid(struct rx_call *a_call, afsUUID * a_uuid);
97 extern int SRXAFSCB_GetServerPrefs(struct rx_call *a_call, afs_int32 a_index,
98                                    afs_int32 * a_srvr_addr,
99                                    afs_int32 * a_srvr_rank);
100 extern int SRXAFSCB_GetCellServDB(struct rx_call *a_call, afs_int32 a_index,
101                                   char **a_name, serverList * a_hosts);
102 extern int SRXAFSCB_GetLocalCell(struct rx_call *a_call, char **a_name);
103 extern int SRXAFSCB_GetCacheConfig(struct rx_call *a_call,
104                                    afs_uint32 callerVersion,
105                                    afs_uint32 * serverVersion,
106                                    afs_uint32 * configCount,
107                                    cacheConfig * config);
108 extern int SRXAFSCB_FetchData(struct rx_call *rxcall, struct AFSFid *Fid,
109                               afs_int32 Fd, afs_int64 Position,
110                               afs_int64 Length, afs_int64 * TotalLength);
111 extern int SRXAFSCB_StoreData(struct rx_call *rxcall, struct AFSFid *Fid,
112                               afs_int32 Fd, afs_int64 Position,
113                               afs_int64 Length, afs_int64 * TotalLength);
114
115
116 /* afs_cbqueue.c */
117 extern afs_rwlock_t afs_xcbhash;
118 extern void afs_QueueCallback(struct vcache *avc, unsigned int atime,
119                               struct volume *avp);
120 extern void afs_CheckCallbacks(unsigned int secs);
121 extern void afs_FlushCBs(void);
122 extern void afs_FlushServerCBs(struct server *srvp);
123 extern int afs_BumpBase(void);
124 extern void afs_InitCBQueue(int doLockInit);
125 extern void afs_DequeueCallback(struct vcache *avc);
126
127 /* afs_cell.c */
128 extern afs_int32 afs_cellindex;
129 extern afs_rwlock_t afs_xcell;
130 extern afs_rwlock_t afsdb_client_lock;
131 extern afs_rwlock_t afsdb_req_lock;
132 extern struct afs_q CellLRU;
133
134 extern void afs_CellInit(void);
135 extern void shutdown_cell(void);
136 extern int afs_cellname_init(afs_dcache_id_t *inode, int lookupcode);
137 extern int afs_cellname_write(void);
138 extern afs_int32 afs_NewCell(char *acellName, afs_int32 * acellHosts,
139                              int aflags, char *linkedcname, u_short fsport,
140                              u_short vlport, int timeout);
141 extern afs_int32 afs_SetPrimaryCell(char *acellName);
142 extern struct cell *afs_GetCell(afs_int32 acell, afs_int32 locktype);
143 extern struct cell *afs_GetCellStale(afs_int32 acell, afs_int32 locktype);
144 extern struct cell *afs_GetCellByHandle(void *handle, afs_int32 locktype);
145 extern struct cell *afs_GetCellByIndex(afs_int32 cellidx, afs_int32 locktype);
146 extern struct cell *afs_GetCellByName(char *acellName, afs_int32 locktype);
147 extern struct cell *afs_GetPrimaryCell(afs_int32 locktype);
148 extern afs_int32 afs_GetPrimaryCellNum(void);
149 extern int afs_IsPrimaryCellNum(afs_int32 cellnum);
150 extern int afs_IsPrimaryCell(struct cell *cell);
151 extern void *afs_TraverseCells(void *(*cb) (struct cell *, void *),
152                                void *arg);
153 extern int afs_CellOrAliasExists(char *aname);
154 extern int afs_CellNumValid(afs_int32 cellnum);
155 extern afs_int32 afs_NewCellAlias(char *alias, char *cell);
156 extern struct cell_alias *afs_GetCellAlias(int index);
157 extern void afs_PutCellAlias(struct cell_alias *a);
158 extern int afs_AFSDBHandler(char *acellName, int acellNameLen,
159                             afs_int32 * kernelMsg);
160 extern void afs_LookupAFSDB(char *acellName);
161 extern void afs_StopAFSDB(void);
162 extern void afs_RemoveCellEntry(struct server *srvp);
163
164 /* afs_chunk.c */
165 extern afs_int32 afs_FirstCSize;
166 extern afs_int32 afs_OtherCSize;
167 extern afs_int32 afs_LogChunk;
168
169 /* afs_cell.c */
170 extern struct cell *afs_GetRealCellByIndex(afs_int32 cellindex,
171                                            afs_int32 locktype,
172                                            afs_int32 refresh);
173
174 /* afs_conn.c */
175 extern afs_int32 cryptall;
176 extern afs_rwlock_t afs_xinterface;
177 extern afs_rwlock_t afs_xconn;
178 extern struct afs_conn *afs_Conn(struct VenusFid *afid,
179                              struct vrequest *areq,
180                              afs_int32 locktype,
181                              struct rx_connection **rxconn);
182 extern struct afs_conn *afs_ConnBySA(struct srvAddr *sap, unsigned short aport,
183                                  afs_int32 acell, struct unixuser *tu,
184                                  int force_if_down, afs_int32 create,
185                                  afs_int32 locktype,
186                                  struct rx_connection **rxconn);
187 extern struct afs_conn *afs_ConnByMHosts(struct server *ahosts[],
188                                      unsigned short aport, afs_int32 acell,
189                                      struct vrequest *areq,
190                                      afs_int32 locktype,
191                                      struct rx_connection **rxconn);
192 extern struct afs_conn *afs_ConnByHost(struct server *aserver,
193                                    unsigned short aport, afs_int32 acell,
194                                    struct vrequest *areq, int aforce,
195                                    afs_int32 locktype,
196                                    struct rx_connection **rxconn);
197 extern void afs_PutConn(struct afs_conn *ac, struct rx_connection *rxconn,
198                         afs_int32 locktype);
199 extern void afs_ReleaseConns(struct sa_conn_vector *tcv);
200 extern void afs_ReleaseConnsUser(register struct unixuser *au);
201 extern void ForceNewConnections(struct srvAddr *sap);
202
203
204 /* afs_daemons.c */
205 extern afs_lock_t afs_xbrs;
206 extern short afs_brsWaiters;
207 extern short afs_brsDaemons;
208 extern struct brequest afs_brs[NBRS];
209 extern struct afs_osi_WaitHandle AFS_WaitHandler, AFS_CSWaitHandler;
210 extern afs_int32 afs_gcpags;
211 extern afs_int32 afs_gcpags_procsize;
212 extern afs_int32 afs_CheckServerDaemonStarted;
213 extern afs_int32 afs_probe_interval;
214 extern afs_int32 afs_preCache;
215
216 extern void afs_Daemon(void);
217 extern struct brequest *afs_BQueue(short aopcode,
218                                    struct vcache *avc,
219                                    afs_int32 dontwait, afs_int32 ause,
220                                    afs_ucred_t *acred,
221                                    afs_size_t asparm0, afs_size_t asparm1,
222                                    void *apparm0, void *apparm1,
223                                    void *apparm2);
224 extern void afs_SetCheckServerNATmode(int isnat);
225 extern void afs_CheckServerDaemon(void);
226 extern int afs_CheckRootVolume(void);
227 extern void afs_BRelease(struct brequest *ab);
228 extern int afs_BBusy(void);
229 extern int afs_BioDaemon(afs_int32 nbiods);
230 #ifdef AFS_DARWIN80_ENV
231 extern int afs_BackgroundDaemon(struct afs_uspc_param *uspc, void *param1, void *param2);
232 #else
233 extern void afs_BackgroundDaemon(void);
234 #endif
235 extern void shutdown_daemons(void);
236 extern int afs_sgidaemon(void);
237
238
239 /* afs_dcache.c */
240 extern u_int afs_min_cache;
241 extern afs_int32 *afs_dvhashTbl;
242 extern afs_int32 afs_dhashsize;
243 extern afs_rwlock_t afs_xdcache;
244 extern afs_size_t afs_vmMappingEnd;
245 extern afs_int32 afs_blocksUsed;
246 extern afs_int32 afs_blocksDiscarded;
247 extern int afs_WaitForCacheDrain;
248 extern int cacheDiskType;
249 extern afs_uint32 afs_tpct1, afs_tpct2, splitdcache;
250 extern unsigned char *afs_indexFlags;
251 extern struct afs_cacheOps *afs_cacheType;
252 extern afs_dcache_id_t cacheInode;
253 extern struct osi_file *afs_cacheInodep;
254 extern void afs_dcacheInit(int afiles, int ablocks, int aDentries, int achunk,
255                            int aflags);
256 extern int afs_PutDCache(struct dcache *adc);
257 extern void afs_FlushDCache(struct dcache *adc);
258 extern void shutdown_dcache(void);
259 extern void afs_CacheTruncateDaemon(void);
260 extern afs_int32 afs_fsfragsize;
261 extern struct dcache *afs_MemGetDSlot(afs_int32 aslot,
262                                       struct dcache *tmpdc);
263 extern struct dcache *afs_GetDCache(struct vcache *avc,
264                                     afs_size_t abyte,
265                                     struct vrequest *areq,
266                                     afs_size_t * aoffset, afs_size_t * alen,
267                                     int aflags);
268 extern struct dcache *afs_FindDCache(struct vcache *avc,
269                                      afs_size_t abyte);
270 extern void afs_StoreWarn(afs_int32 acode, afs_int32 avolume,
271                           afs_int32 aflags);
272 extern void afs_MaybeWakeupTruncateDaemon(void);
273 extern void afs_CacheTruncateDaemon(void);
274 extern void afs_AdjustSize(struct dcache *adc,
275                            afs_int32 newSize);
276 extern int afs_HashOutDCache(struct dcache *adc, int zap);
277 extern int afs_MaybeFreeDiscardedDCache(void);
278 extern int afs_RefDCache(struct dcache *adc);
279 extern void afs_TryToSmush(struct vcache *avc,
280                            afs_ucred_t *acred, int sync);
281 extern void updateV2DC(int lockVc, struct vcache *v, struct dcache *d,
282                        int src);
283 extern void afs_WriteThroughDSlots(void);
284 extern struct dcache *afs_UFSGetDSlot(afs_int32 aslot,
285                                       struct dcache *tmpdc);
286 extern int afs_WriteDCache(struct dcache *adc, int atime);
287 extern int afs_wakeup(struct vcache *avc);
288 extern int afs_InitCacheFile(char *afile, ino_t ainode);
289 extern int afs_DCacheMissingChunks(struct vcache *avc);
290 extern struct dcache *afs_ObtainDCacheForWriting(struct vcache *avc,
291                                                  afs_size_t filePos,
292                                                  afs_size_t len,
293                                                  struct vrequest *areq,
294                                                  int noLock);
295 extern void afs_PopulateDCache(struct vcache *avc, afs_size_t apos,
296                                struct vrequest *areq);
297
298 /* afs_disconnected.c */
299
300 /* afs_dynroot.c */
301 extern int afs_IsDynrootFid(struct VenusFid *fid);
302 extern int afs_IsDynrootMountFid(struct VenusFid *fid);
303 extern int afs_IsDynrootAnyFid(struct VenusFid *fid);
304 extern void afs_GetDynrootFid(struct VenusFid *fid);
305 extern void afs_GetDynrootMountFid(struct VenusFid *fid);
306 extern int afs_IsDynroot(struct vcache *avc);
307 extern int afs_IsDynrootMount(struct vcache *avc);
308 extern int afs_IsDynrootAny(struct vcache *avc);
309 extern void afs_DynrootInvalidate(void);
310 extern void afs_GetDynroot(char **dynrootDir, int *dynrootLen,
311                            struct AFSFetchStatus *status);
312 extern void afs_GetDynrootMount(char **dynrootDir, int *dynrootLen,
313                            struct AFSFetchStatus *status);
314 extern void afs_PutDynroot(void);
315 extern int afs_DynrootNewVnode(struct vcache *avc,
316                                struct AFSFetchStatus *status);
317 extern int afs_InitDynroot(void);
318 extern int afs_SetDynrootEnable(int enable);
319 extern int afs_GetDynrootEnable(void);
320 extern int afs_DynrootVOPRemove(struct vcache *avc, afs_ucred_t *acred,
321                                 char *aname);
322 extern int afs_DynrootVOPSymlink(struct vcache *avc, afs_ucred_t *acred,
323                                  char *aname, char *atargetName);
324
325 /* afs_error.c */
326 extern void init_et_to_sys_error(void);
327 extern afs_int32 et_to_sys_error(afs_int32 in);
328 extern void afs_FinalizeReq(struct vrequest *areq);
329 extern int afs_CheckCode(afs_int32 acode, struct vrequest *areq, int where);
330 extern void afs_CopyError(struct vrequest *afrom,
331                           struct vrequest *ato);
332 extern void init_sys_error_to_et(void);
333
334 /* afs_exporter.c */
335 extern struct afs_exporter *root_exported;
336 extern struct afs_exporter *exporter_find(int type);
337 extern void shutdown_exporter(void);
338
339 /* afs_fetchstore.c */
340 extern int afs_UFSCacheFetchProc(struct rx_call *, struct osi_file *,
341                                  afs_size_t, struct dcache *,
342                                  struct vcache *, afs_size_t *,
343                                  afs_size_t *, afs_int32);
344
345 extern int afs_UFSCacheStoreProc(struct rx_call *, struct osi_file *,
346                                  afs_int32, struct vcache *,
347                                  int *, afs_size_t *,
348                                  afs_size_t *);
349
350 /* afs_icl.c */
351 extern struct afs_icl_set *afs_icl_allSets;
352 extern int afs_icl_InitLogs(void);
353 extern void shutdown_icl(void);
354 extern int afs_icl_CreateLog(char *name, afs_int32 logSize,
355                              struct afs_icl_log **outLogpp);
356 extern int afs_icl_CreateLogWithFlags(char *name, afs_int32 logSize,
357                                       afs_uint32 flags,
358                                       struct afs_icl_log **outLogpp);
359 extern int afs_icl_CopyOut(struct afs_icl_log *logp,
360                            afs_int32 * bufferp, afs_int32 * bufSizep,
361                            afs_uint32 * cookiep, afs_int32 * flagsp);
362 extern int afs_icl_GetLogParms(struct afs_icl_log *logp, afs_int32 * maxSizep,
363                                afs_int32 * curSizep);
364 extern int afs_icl_LogHold(struct afs_icl_log *logp);
365 extern int afs_icl_LogHoldNL(struct afs_icl_log *logp);
366 extern int afs_icl_LogUse(struct afs_icl_log *logp);
367 extern int afs_icl_LogFreeUse(struct afs_icl_log *logp);
368 extern int afs_icl_LogSetSize(struct afs_icl_log *logp,
369                               afs_int32 logSize);
370 extern int afs_icl_ZapLog(struct afs_icl_log *logp);
371 extern int afs_icl_LogRele(struct afs_icl_log *logp);
372 extern int afs_icl_LogReleNL(struct afs_icl_log *logp);
373 extern int afs_icl_ZeroLog(struct afs_icl_log *logp);
374 extern int afs_icl_LogFree(struct afs_icl_log *logp);
375 extern struct afs_icl_log *afs_icl_FindLog(char *name);
376 extern int
377   afs_icl_EnumerateLogs(int (*aproc)
378
379                           (char *name, char *arock, struct afs_icl_log * tp),
380                         char *arock);
381 extern int afs_icl_CreateSet(char *name, struct afs_icl_log *baseLogp,
382                              struct afs_icl_log *fatalLogp,
383                              struct afs_icl_set **outSetpp);
384 extern int afs_icl_CreateSetWithFlags(char *name,
385                                       struct afs_icl_log *baseLogp,
386                                       struct afs_icl_log *fatalLogp,
387                                       afs_uint32 flags,
388                                       struct afs_icl_set **outSetpp);
389 extern int afs_icl_SetEnable(struct afs_icl_set *setp, afs_int32 eventID,
390                              int setValue);
391 extern int afs_icl_GetEnable(struct afs_icl_set *setp, afs_int32 eventID,
392                              int *getValuep);
393 extern int afs_icl_ZeroSet(struct afs_icl_set *setp);
394 extern int
395   afs_icl_EnumerateSets(int (*aproc)
396
397                           (char *name, char *arock, struct afs_icl_log * tp),
398                         char *arock);
399 extern int afs_icl_AddLogToSet(struct afs_icl_set *setp,
400                                struct afs_icl_log *newlogp);
401 extern int afs_icl_SetSetStat(struct afs_icl_set *setp, int op);
402 extern int afs_icl_SetHold(struct afs_icl_set *setp);
403 extern int afs_icl_ZapSet(struct afs_icl_set *setp);
404 extern int afs_icl_SetRele(struct afs_icl_set *setp);
405 extern int afs_icl_SetFree(struct afs_icl_set *setp);
406 extern struct afs_icl_set *afs_icl_FindSet(char *name);
407
408 extern int afs_icl_Event4(struct afs_icl_set *setp,
409                           afs_int32 eventID, afs_int32 lAndT, long p1,
410                           long p2, long p3, long p4);
411 extern int afs_icl_Event3(struct afs_icl_set *setp,
412                           afs_int32 eventID, afs_int32 lAndT, long p1,
413                           long p2, long p3);
414 extern int afs_icl_Event2(struct afs_icl_set *setp,
415                           afs_int32 eventID, afs_int32 lAndT, long p1,
416                           long p2);
417 extern int afs_icl_Event1(struct afs_icl_set *setp,
418                           afs_int32 eventID, afs_int32 lAndT, long p1);
419 extern int afs_icl_Event0(struct afs_icl_set *setp,
420                           afs_int32 eventID, afs_int32 lAndT);
421 extern void afs_icl_AppendRecord(struct afs_icl_log *logp,
422                                  afs_int32 op, afs_int32 types, long p1,
423                                  long p2, long p3, long p4);
424 extern int Afscall_icl(long opcode, long p1, long p2, long p3, long p4,
425                        long *retval);
426 #ifdef AFS_DARWIN100_ENV
427 extern int Afscall64_icl(int opcode, user_addr_t p1, user_addr_t p2,
428                        user_addr_t p3, user_addr_t p4, int *retval);
429 #endif
430
431 /* afs_init.c */
432 extern struct cm_initparams cm_initParams;
433 extern int afs_resourceinit_flag;
434 extern afs_rwlock_t afs_puttofileLock;
435 extern char *afs_sysname;
436 extern char *afs_sysnamelist[MAXNUMSYSNAMES];
437 extern int afs_sysnamecount;
438 extern int afs_sysnamegen;
439 extern afs_int32 cacheInfoModTime;
440 extern int afs_CacheInit(afs_int32 astatSize, afs_int32 afiles,
441                          afs_int32 ablocks, afs_int32 aDentries,
442                          afs_int32 aVolumes, afs_int32 achunk,
443                          afs_int32 aflags, afs_int32 ninodes,
444                          afs_int32 nusers, afs_int32 dynamic_vcaches);
445 extern void afs_ComputeCacheParms(void);
446 extern int afs_InitCacheInfo(char *afile);
447 extern int afs_InitVolumeInfo(char *afile);
448 extern int afs_InitCellInfo(char *afile);
449 extern int afs_ResourceInit(int preallocs);
450 extern void shutdown_cache(void);
451 extern void shutdown_vnodeops(void);
452 extern void shutdown_AFS(void);
453 extern int afs_LookupInodeByPath(char *filename, afs_ufs_dcache_id_t *inode,
454                                  struct vnode **fvpp);
455
456 /* afs_lock.c */
457 extern void Lock_Init(struct afs_lock *lock);
458 extern void ObtainLock(struct afs_lock *lock, int how,
459                        unsigned int src_indicator);
460 extern void ReleaseLock(struct afs_lock *lock, int how);
461 extern int Afs_Lock_Trace(int op, struct afs_lock *alock, int type,
462                           char *file, int line);
463 extern void Afs_Lock_Obtain(struct afs_lock *lock, int how);
464 extern void Afs_Lock_ReleaseR(struct afs_lock *lock);
465 extern void Afs_Lock_ReleaseW(struct afs_lock *lock);
466 extern void afs_osi_SleepR(char *addr,
467                            struct afs_lock *alock);
468 extern void afs_osi_SleepW(char *addr,
469                            struct afs_lock *alock);
470 extern void afs_osi_SleepS(char *addr,
471                            struct afs_lock *alock);
472 #ifndef AFS_NOBOZO_LOCK
473 extern void afs_BozonLock(struct afs_bozoLock *alock, struct vcache *avc);
474 extern void afs_BozonUnlock(struct afs_bozoLock *alock, struct vcache *avc);
475 extern void afs_BozonInit(struct afs_bozoLock *alock, struct vcache *avc);
476 extern int afs_CheckBozonLock(struct afs_bozoLock *alock);
477 extern int afs_CheckBozonLockBlocking(struct afs_bozoLock *alock);
478 #endif
479
480
481
482
483 /* afs_mariner.c */
484 extern afs_int32 afs_mariner;
485 extern afs_int32 afs_marinerHost;
486 extern struct rx_service *afs_server;
487 extern int afs_AddMarinerName(char *aname,
488                               struct vcache *avc);
489 extern char *afs_GetMariner(struct vcache *avc);
490 extern void afs_MarinerLogFetch(struct vcache *avc,
491                                 afs_int32 off,
492                                 afs_int32 bytes,
493                                 afs_int32 idx);
494 extern void afs_MarinerLog(char *astring,
495                            struct vcache *avc);
496 extern void shutdown_mariner(void);
497
498 /* afs_fetchstore.c */
499 extern int afs_CacheStoreVCache(struct dcache **dcList, struct vcache *avc,
500                                 struct vrequest *areq,
501                                 int sync, unsigned int minj,
502                                 unsigned int high, unsigned int moredata,
503                                 afs_hyper_t *anewDV,
504                                  afs_size_t *amaxStoredLength);
505 extern int afs_CacheFetchProc(struct afs_conn *tc, struct rx_connection *rxconn,
506                                 struct osi_file *fP,
507                                 afs_size_t abase, struct dcache *adc,
508                                 struct vcache *avc, afs_int32 size,
509                                 struct afs_FetchOutput *tsmall);
510
511 /* afs_memcache.c */
512 extern int afs_InitMemCache(int blkCount, int blkSize, int flags);
513 extern int afs_MemCacheClose(struct osi_file *file);
514 extern void *afs_MemCacheOpen(afs_dcache_id_t *ainode);
515 extern int afs_MemReadBlk(struct osi_file *fP, int offset,
516                           void *dest, int size);
517 extern int afs_MemReadvBlk(struct memCacheEntry *mceP, int offset,
518                            struct iovec *iov, int nio, int size);
519 extern int afs_MemReadUIO(afs_dcache_id_t *ainode, struct uio *uioP);
520 extern int afs_MemWriteBlk(struct osi_file *fP, int offset,
521                            void *src, int size);
522 extern int afs_MemWritevBlk(struct memCacheEntry *mceP, int offset,
523                             struct iovec *iov, int nio, int size);
524 extern int afs_MemWriteUIO(struct vcache *, afs_dcache_id_t *, struct uio *);
525 extern int afs_MemCacheTruncate(struct osi_file *fP,
526                                 int size);
527 extern void shutdown_memcache(void);
528
529
530 /* afs_nfsclnt.c */
531 extern struct afs_exporter *afs_nfsexported;
532 extern struct afs_exporter *afs_nfsexporter;
533 extern void afs_nfsclient_init(void);
534 extern int afs_nfsclient_reqhandler(struct afs_exporter *exporter,
535                                     afs_ucred_t **cred,
536                                     afs_uint32 host, afs_int32 *pagparam,
537                                     struct afs_exporter **outexporter);
538 extern void shutdown_nfsclnt(void);
539
540 /* afs_osi.c */
541 extern afs_lock_t afs_ftf;
542 extern void afs_osi_Invisible(void);
543 extern void afs_osi_Visible(void);
544 extern void afs_osi_RxkRegister(void);
545 extern void afs_osi_MaskSignals(void);
546 extern void afs_osi_UnmaskRxkSignals(void);
547 extern void afs_osi_MaskUserLoop(void);
548 extern void osi_Init(void);
549 extern void afs_osi_MaskSignals(void);
550 extern void afs_osi_UnmaskRxkSignals(void);
551 extern void afs_osi_RxkRegister(void);
552 extern void afs_osi_Invisible(void);
553 extern void shutdown_osi(void);
554 extern void shutdown_osinet(void);
555 extern int afs_osi_suser(void *credp);
556 extern void afs_osi_TraverseProcTable(void);
557 #if defined(KERNEL) && !defined(UKERNEL)
558 extern const afs_ucred_t *afs_osi_proc2cred(afs_proc_t * pr);
559 #endif
560
561 /* afs_osi_alloc.c */
562 #ifndef AFS_PRIVATE_OSI_ALLOCSPACES
563 extern afs_lock_t osi_fsplock;
564 extern afs_lock_t osi_flplock;
565 #endif
566
567 extern void *afs_osi_Alloc_debug(size_t x, char *func, int line);
568 #ifndef afs_osi_Free
569 extern void afs_osi_Free(void *x, size_t asize);
570 #endif
571 #if !defined(AFS_OBSD44_ENV)
572 extern void afs_osi_FreeStr(char *x);
573 #endif
574 extern void osi_FreeLargeSpace(void *adata);
575 extern void osi_FreeSmallSpace(void *adata);
576 extern void *osi_AllocLargeSpace(size_t size);
577 extern void *osi_AllocSmallSpace(size_t size);
578 extern void shutdown_osinet(void);
579
580 /* afs_osi_pag.c */
581 #if defined(AFS_SUN5_ENV)
582 extern int afs_setpag(afs_ucred_t **credpp);
583 #elif defined(AFS_FBSD_ENV)
584 extern int afs_setpag(struct thread *td, void *args);
585 #elif defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
586 extern int afs_setpag(afs_proc_t *p, void *args, int *retval);
587 #else
588 extern int afs_setpag(void);
589 #endif
590
591 extern afs_uint32 genpag(void);
592 extern afs_uint32 getpag(void);
593 #if defined(AFS_FBSD_ENV)
594 extern int AddPag(struct thread *td, afs_int32 aval, afs_ucred_t **credpp);
595 #elif defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
596 extern int AddPag(afs_proc_t *p, afs_int32 aval, afs_ucred_t **credpp);
597 #else
598 extern int AddPag(afs_int32 aval, afs_ucred_t **credpp);
599 #endif
600 extern int afs_InitReq(struct vrequest *av, afs_ucred_t *acred);
601 extern afs_uint32 afs_get_pag_from_groups(gid_t g0a, gid_t g1a);
602 extern void afs_get_groups_from_pag(afs_uint32 pag, gid_t * g0p, gid_t * g1p);
603 extern afs_int32 PagInCred(afs_ucred_t *cred);
604
605 /* afs_osi_uio.c */
606 extern int afsio_copy(struct uio *ainuio, struct uio *aoutuio,
607                       struct iovec *aoutvec);
608 extern int afsio_trim(struct uio *auio, afs_int32 asize);
609 extern int afsio_skip(struct uio *auio, afs_int32 asize);
610
611 /* afs_osi_vm.c */
612 extern int osi_Active(struct vcache *avc);
613 extern void osi_FlushPages(struct vcache *avc,
614                            afs_ucred_t *credp);
615 extern void osi_FlushText_really(struct vcache *vp);
616 extern int osi_VMDirty_p(struct vcache *avc);
617 #ifndef UKERNEL
618 extern void osi_ReleaseVM(struct vcache *avc, afs_ucred_t *acred);
619 #endif
620
621
622 /* LINUX/osi_fetchstore.c */
623 #ifdef AFS_LINUX26_ENV
624 extern int afs_linux_storeproc(struct storeOps *, void *, struct dcache *,
625                                int *, afs_size_t *);
626 #endif
627
628 /* ARCH/osi_crypto.c */
629 extern int osi_readRandom(void *, afs_size_t);
630
631 /* ARCH/osi_misc.c */
632 extern void afs_osi_SetTime(osi_timeval_t * atv);
633
634 /* LINUX/osi_misc.c */
635 #ifdef AFS_LINUX20_ENV
636 #ifdef AFS_LINUX24_ENV
637 extern int osi_lookupname(char *aname, uio_seg_t seg, int followlink,
638                           struct dentry **dpp);
639 extern int osi_InitCacheInfo(char *aname);
640 extern int osi_rdwr(struct osi_file *osifile, uio_t * uiop, int rw);
641 extern void setup_uio(uio_t * uiop, struct iovec *iovecp, const char *buf,
642                       afs_offs_t pos, int count, uio_flag_t flag,
643                       uio_seg_t seg);
644 extern int uiomove(char *dp, int length, uio_flag_t rw, uio_t * uiop);
645 extern void osi_linux_free_inode_pages(void);
646 #endif
647 extern void osi_linux_mask(void);
648 extern void osi_linux_unmask(void);
649 extern int setpag(cred_t ** cr, afs_uint32 pagvalue, afs_uint32 * newpag,
650                   int change_parent);
651 #endif
652
653
654 /* ARCH/osi_sleep.c */
655 extern void afs_osi_InitWaitHandle(struct afs_osi_WaitHandle *achandle);
656 extern void afs_osi_CancelWait(struct afs_osi_WaitHandle *achandle);
657 extern int afs_osi_Wait(afs_int32 ams, struct afs_osi_WaitHandle *ahandle,
658                         int aintok);
659 extern int afs_osi_TimedSleep(void *event, afs_int32 ams, int aintok);
660 #ifndef afs_osi_Wakeup
661 extern int afs_osi_Wakeup(void *event);
662 #endif
663 #ifndef afs_osi_Sleep
664 extern void afs_osi_Sleep(void *event);
665 #endif
666 #ifndef afs_osi_SleepSig
667 extern int afs_osi_SleepSig(void *event);
668 #endif
669
670
671 /* ARCH/osi_inode.c */
672 #ifdef AFS_SUN5_ENV
673 extern int afs_syscall_icreate(dev_t, long, long, long, long, long,
674                                rval_t *, afs_ucred_t *);
675 extern int afs_syscall_iopen(dev_t, int, int, rval_t *, afs_ucred_t *);
676 extern int afs_syscall_iincdec(dev_t, int, int, int, rval_t *,
677                                afs_ucred_t *);
678 #elif defined(AFS_SGI65_ENV)
679 extern int afs_syscall_icreate(afs_uint32, afs_uint32, afs_uint32, afs_uint32, afs_uint32, afs_uint32, rval_t *);
680 extern int afs_syscall_iopen(int, ino_t, int, rval_t *);
681 extern int afs_syscall_iincdec(int, int, int, int);
682 #elif defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
683 extern int afs_syscall_icreate(long, long, long, long, long, long, long*);
684 extern int afs_syscall_iopen(int dev, int inode, int usrmod, long *retval);
685 extern int afs_syscall_iincdec(int dev, int inode, int inode_p1, int amount);
686 #else
687 extern int afs_syscall_icreate(long, long, long, long, long, long);
688 extern int afs_syscall_iopen(int, int, int);
689 extern int afs_syscall_iincdec(int, int, int, int);
690 #endif
691
692 /* ARCH/osi_file.c */
693 extern int afs_osicred_initialized;
694 extern void *osi_UFSOpen(afs_dcache_id_t *ainode);
695 #if defined(AFS_LINUX22_ENV)
696 extern void osi_get_fh(struct dentry *dp, afs_ufs_dcache_id_t *ainode);
697 #endif
698 extern int afs_osi_Stat(struct osi_file *afile,
699                         struct osi_stat *astat);
700 extern int osi_UFSClose(struct osi_file *afile);
701 extern int osi_UFSTruncate(struct osi_file *afile, afs_int32 asize);
702 extern void osi_DisableAtimes(struct vnode *avp);
703 extern int afs_osi_Read(struct osi_file *afile, int offset,
704                         void *aptr, afs_int32 asize);
705 extern int afs_osi_Write(struct osi_file *afile, afs_int32 offset,
706                          void *aptr, afs_int32 asize);
707 extern int afs_osi_MapStrategy(int (*aproc) (struct buf * bp),
708                                struct buf *bp);
709 extern void shutdown_osifile(void);
710
711
712 /* ARCH/osi_groups.c */
713 #if defined(UKERNEL)
714 extern int usr_setpag(afs_ucred_t **cred, afs_uint32 pagvalue,
715                       afs_uint32 * newpag, int change_parent);
716 #else
717 # if defined AFS_XBSD_ENV
718 #  if !defined(AFS_DFBSD_ENV)
719 #   if defined(AFS_FBSD_ENV)
720 extern int setpag(struct thread *td, struct ucred **cred, afs_uint32 pagvalue,
721                   afs_uint32 * newpag, int change_parent);
722
723 #   elif defined(AFS_NBSD40_ENV)
724 extern int setpag(struct proc *proc, afs_ucred_t *cred, afs_uint32 pagvalue,
725                   afs_uint32 * newpag, int change_parent);
726 #   else
727 extern int setpag(afs_proc_t *proc, struct ucred **cred, afs_uint32 pagvalue,
728                   afs_uint32 * newpag, int change_parent);
729 #   endif /* AFS_FBSD_ENV */
730 #  endif /* ! AFS_DFBSD_ENV */
731 # endif /* AFS_XBSD_ENV */
732 #endif /* UKERNEL */
733
734 #if defined(AFS_LINUX26_ENV)
735 extern afs_int32 osi_get_group_pag(afs_ucred_t *cred);
736 #endif
737
738
739
740 /* ARCH/osi_vm.c */
741 extern int osi_VM_FlushVCache(struct vcache *avc, int *slept);
742 extern void osi_VM_StoreAllSegments(struct vcache *avc);
743 extern void osi_VM_TryToSmush(struct vcache *avc, afs_ucred_t *acred,
744                               int sync);
745 extern void osi_VM_FlushPages(struct vcache *avc, afs_ucred_t *credp);
746 extern void osi_VM_Truncate(struct vcache *avc, int alen,
747                             afs_ucred_t *acred);
748 extern void osi_VM_TryReclaim(struct vcache *avc, int *slept);
749 extern void osi_VM_NukePages(struct vnode *vp, off_t offset, off_t size);
750 extern int osi_VM_Setup(struct vcache *avc, int force);
751
752 #ifdef AFS_SUN5_ENV
753 extern int osi_VM_GetDownD(struct vcache *avc, struct dcache *adc);
754 extern void osi_VM_PreTruncate(struct vcache *avc, int alen,
755                                afs_ucred_t *acred);
756 #endif
757
758
759 /* ARCH/osi_vnodeops.c */
760 extern struct vnodeops Afs_vnodeops;
761 extern int afs_inactive(struct vcache *avc, afs_ucred_t *acred);
762
763 /* afs_osifile.c */
764
765 /* afs_osi_pag.c */
766 extern afs_uint32 pag_epoch;
767 extern afs_uint32 pagCounter;
768
769 /* OS/osi_vfsops.c */
770 #if defined(AFS_XBSD_ENV) || defined(AFS_DARWIN_ENV)
771 extern struct mount *afs_globalVFS;
772 #else
773 extern struct vfs *afs_globalVFS;
774 #endif
775 extern struct vcache *afs_globalVp;
776 #ifdef AFS_LINUX20_ENV
777 extern void vcache2inode(struct vcache *avc);
778 extern void vcache2fakeinode(struct vcache *rootvp, struct vcache *mpvp);
779 #endif
780
781 #ifdef UKERNEL
782 extern int afs_mount(struct vfs *afsp, char *path, void *data);
783 extern int afs_root(OSI_VFS_DECL(afsp), struct vnode **avpp);
784 extern int afs_unmount(struct vfs *afsp);
785 #endif
786
787 /* afs_pag_call.c */
788 extern afs_int32 afs_nfs_server_addr;
789 extern void afspag_Init(afs_int32 nfs_server_addr);
790 extern void afspag_Shutdown(void);
791
792 /* afs_pag_cred.c */
793 extern afs_rwlock_t afs_xpagcell;
794 extern afs_rwlock_t afs_xpagsys;
795 extern int afspag_PUnlog(char *ain, afs_int32 ainSize,
796                          afs_ucred_t **acred);
797 extern int afspag_PSetTokens(char *ain, afs_int32 ainSize,
798                              afs_ucred_t **acred);
799 extern int afspag_PSetSysName(char *ain, afs_int32 ainSize,
800                               afs_ucred_t **acred);
801
802 /* afs_pioctl.c */
803 extern struct VenusFid afs_rootFid;
804 extern afs_int32 afs_waitForever;
805 extern short afs_waitForeverCount;
806 extern afs_int32 afs_showflags;
807 extern int afs_defaultAsynchrony;
808 #if defined(AFS_DARWIN100_ENV)
809 extern int afs_syscall64_pioctl(user_addr_t path, unsigned int com,
810                                 user_addr_t cmarg, int follow, \
811                                 afs_ucred_t *credp);
812 #endif
813 #ifdef AFS_SUN5_ENV
814 extern int afs_syscall_pioctl(char *path, unsigned int com, caddr_t cmarg,
815                               int follow, rval_t *rvp, afs_ucred_t *credp);
816 #elif defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
817 extern int afs_syscall_pioctl(char *path, unsigned int com, caddr_t cmarg,
818                               int follow, afs_ucred_t *credp);
819 #else
820 extern int afs_syscall_pioctl(char *path, unsigned int com, caddr_t cmarg,
821                               int follow);
822 #endif
823 extern int HandleIoctl(struct vcache *avc, afs_int32 acom,
824                        struct afs_ioctl *adata);
825
826
827 /* afs_segments.c */
828 extern int afs_StoreAllSegments(struct vcache *avc,
829                                 struct vrequest *areq, int sync);
830 extern int afs_InvalidateAllSegments(struct vcache *avc);
831 extern int afs_ExtendSegments(struct vcache *avc,
832                               afs_size_t alen, struct vrequest *areq);
833 extern int afs_TruncateAllSegments(struct vcache *avc,
834                                    afs_size_t alen, struct vrequest *areq,
835                                    afs_ucred_t *acred);
836
837 /* afs_server.c */
838 extern afs_rwlock_t afs_xsrvAddr;
839 extern afs_rwlock_t afs_xserver;
840 extern afs_rwlock_t afs_icl_lock;
841 extern struct srvAddr *afs_srvAddrs[NSERVERS];
842 extern struct server *afs_servers[NSERVERS];
843 extern int afs_totalServers;
844 extern struct server *afs_setTimeHost;
845 extern struct server *afs_FindServer(afs_int32 aserver, afs_uint16 aport,
846                                      afsUUID * uuidp, afs_int32 locktype);
847 extern struct server *afs_GetServer(afs_uint32 * aserver, afs_int32 nservers,
848                                     afs_int32 acell, u_short aport,
849                                     afs_int32 locktype, afsUUID * uuidp,
850                                     afs_int32 addr_uniquifier);
851 extern void afs_GetCapabilities(struct server *ts);
852 extern void ForceAllNewConnections(void);
853 extern void afs_MarkServerUpOrDown(struct srvAddr *sa, int a_isDown);
854 extern afs_int32 afs_ServerDown(struct srvAddr *sa);
855 extern void afs_CountServers(void);
856 extern void afs_CheckServers(int adown, struct cell *acellp);
857 extern void afs_LoopServers(int adown, struct cell *acellp, int vlalso,
858                             void (*func1) (struct rx_connection **rxconns,
859                                            int nconns, int nservers,
860                                            struct afs_conn **conns,
861                                            struct srvAddr **addrs),
862                             void (*func2) (struct rx_connection **rxconns,
863                                            int nconns, int nservers,
864                                            struct afs_conn **conns,
865                                            struct srvAddr **addrs));
866 extern unsigned int afs_random(void);
867 extern int afs_randomMod15(void);
868 extern int afs_randomMod127(void);
869 extern void afs_SortOneServer(struct server *asp);
870 extern void afs_SortServers(struct server *aservers[], int count);
871 extern void afs_FlushServer(struct server *srvp);
872 extern void afs_RemoveSrvAddr(struct srvAddr *sap);
873 extern void afs_ActivateServer(struct srvAddr *sap);
874 #ifdef AFS_USERSPACE_IP_ADDR
875 extern void afsi_SetServerIPRank(struct srvAddr *sa, afs_int32 addr,
876                                 afs_uint32 subnetmask);
877 #else
878 #if (!defined(AFS_SUN5_ENV)) && defined(USEIFADDR)
879 void afsi_SetServerIPRank(struct srvAddr *sa, struct in_ifaddr *ifa);
880 #endif
881 #endif
882 extern int afs_HaveCallBacksFrom(struct server *aserver);
883 extern void afs_RemoveAllConns(void);
884 extern void afs_MarkAllServersUp(void);
885
886 /* afs_osidnlc.c */
887 extern int osi_dnlc_enter(struct vcache *adp, char *aname, struct vcache *avc,
888                           afs_hyper_t * avno);
889 extern struct vcache *osi_dnlc_lookup(struct vcache *adp, char *aname,
890                                       int locktype);
891 extern int osi_dnlc_remove(struct vcache *adp, char *aname,
892                            struct vcache *avc);
893 extern int osi_dnlc_purgedp(struct vcache *adp);
894 extern int osi_dnlc_purgevp(struct vcache *avc);
895 extern int osi_dnlc_purge(void);
896 extern int osi_dnlc_purgevol(struct VenusFid *fidp);
897 extern int osi_dnlc_init(void);
898 extern int osi_dnlc_shutdown(void);
899
900 /* afs_pag_cred.c */
901 extern void afspag_SetPrimaryCell(char *acell);
902
903 /* afs_stat.c */
904 extern struct afs_CMStats afs_cmstats;
905 extern struct afs_stats_CMPerf afs_stats_cmperf;
906 extern struct afs_stats_CMFullPerf afs_stats_cmfullperf;
907 extern afs_int32 afs_stats_XferSumBytes[AFS_STATS_NUM_FS_XFER_OPS];
908 extern void afs_InitStats(void);
909 extern void afs_GetCMStat(char **ptr, unsigned *size);
910 #ifndef AFS_NOSTATS
911 extern void afs_AddToMean(struct afs_MeanStats *oldMean, afs_int32 newValue);
912 #endif
913
914 /* afs_syscall.c */
915 #ifdef AFS_DARWIN100_ENV
916 extern int copyin_afs_ioctl(user_addr_t cmarg, struct afs_ioctl *dst);
917 #else
918 extern int copyin_afs_ioctl(caddr_t cmarg, struct afs_ioctl *dst);
919 #endif
920
921 #if defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
922 #ifdef AFS_DARWIN100_ENV
923 extern int afs3_syscall(afs_proc_t *p, void *args, unsigned int *retval);
924 #elif defined(AFS_FBSD90_ENV) || defined(AFS_FBSD82_ENV)
925 /* afs3_syscall prototype is in sys/sysproto.h */
926 #elif defined(AFS_FBSD_ENV)
927 extern int afs3_syscall(struct thread *p, void *args);
928 #elif defined(AFS_NBSD40_ENV)
929 extern int afs3_syscall(struct lwp *p, void *args);
930 #else
931 extern int afs3_syscall(afs_proc_t *p, void *args, long *retval);
932 #endif
933 #endif
934
935 #ifdef UKERNEL
936 extern int Afs_syscall(void);
937 #endif
938
939 /* afs_tokens.c */
940 struct ktc_tokenUnion;
941 struct ktc_setTokenData;
942
943 extern union tokenUnion *afs_FindToken(struct tokenJar *, rx_securityIndex);
944 extern void afs_FreeTokens(struct tokenJar **);
945 extern union tokenUnion *afs_AddToken(struct tokenJar **, rx_securityIndex);
946 extern void afs_DiscardExpiredTokens(struct tokenJar **, afs_int32);
947 extern int afs_HasValidTokens(struct tokenJar *, afs_int32);
948 extern int afs_HasUsableTokens(struct tokenJar *, afs_int32);
949 extern void afs_AddRxkadToken(struct tokenJar **, char *, int,
950                               struct ClearToken *);
951 extern int afs_AddTokenFromPioctl(struct tokenJar **, struct ktc_tokenUnion *);
952 extern int afs_ExtractTokensForPioctl(struct tokenJar *, time_t,
953                                       struct ktc_setTokenData *);
954
955 /* UKERNEL/afs_usrops.c */
956 #ifdef UKERNEL
957 extern void uafs_Shutdown(void);
958 extern void osi_ReleaseVM(struct vcache *avc, int len,
959                           afs_ucred_t *credp);
960 extern int osi_GetTime(struct timeval *tv);
961 extern int iodone(struct usr_buf *bp);
962 extern int usr_ioctl(void);
963 extern int lookupname(char *fnamep, int segflg, int followlink,
964                       struct usr_vnode **compvpp);
965 extern int usr_uiomove(char *kbuf, int n, int rw, struct usr_uio *uio);
966 extern int afs_osi_VOP_RDWR(struct usr_vnode *vnodeP, struct usr_uio *uioP,
967                             int rw, int flags, afs_ucred_t *credP);
968
969 #endif
970
971 /* afs_user.c */
972 extern afs_rwlock_t afs_xuser;
973 extern struct unixuser *afs_users[NUSERS];
974 extern struct unixuser *afs_FindUser(afs_int32 auid, afs_int32 acell,
975                                      afs_int32 locktype);
976 extern struct unixuser *afs_GetUser(afs_int32 auid, afs_int32 acell,
977                                     afs_int32 locktype);
978 extern void afs_NotifyUser(struct unixuser *auser, int event);
979
980 #if AFS_GCPAGS
981 extern afs_int32 afs_GCPAGs(afs_int32 * ReleasedCount);
982 extern void afs_GCPAGs_perproc_func(afs_proc_t * pproc);
983 #endif /* AFS_GCPAGS */
984 extern void afs_ComputePAGStats(void);
985 extern void afs_PutUser(struct unixuser *au, afs_int32 locktype);
986 extern void afs_GCUserData(int aforce);
987 extern void afs_CheckTokenCache(void);
988 extern void afs_ResetAccessCache(afs_int32 uid, int alock);
989 extern void afs_ResetUserConns(struct unixuser *auser);
990 extern void afs_SetPrimary(struct unixuser *au, int aflag);
991 extern void afs_MarkUserExpired(afs_int32 pag);
992
993 /* afs_util.c */
994 extern afs_int32 afs_strtoi_r(const char *str, char **endptr, afs_uint32 *ret);
995 extern afs_int32 afs_calc_inum (afs_int32 volume, afs_int32 vnode);
996 #ifndef afs_cv2string
997 extern char *afs_cv2string(char *ttp, afs_uint32 aval);
998 #endif
999 #ifndef afs_strcasecmp
1000 extern int afs_strcasecmp(char *s1, char *s2);
1001 #endif
1002 #ifndef afs_strcat
1003 extern char *afs_strcat(char *s1, char *s2);
1004 #endif
1005 #ifdef AFS_OBSD34_ENV
1006 extern char *afs_strcpy(char *s1, char *s2);
1007 #endif
1008 #ifndef afs_strchr
1009 extern char *afs_strchr(char *s, int c);
1010 #endif
1011 #ifndef afs_strrchr
1012 extern char *afs_strrchr(char *s, int c);
1013 #endif
1014 extern char *afs_strdup(char *s);
1015 extern void print_internet_address(char *preamble, struct srvAddr *sa,
1016                                    char *postamble, int flag);
1017 extern afs_int32 afs_data_pointer_to_int32(const void *p);
1018
1019 extern void afs_CheckLocks(void);
1020 extern int afs_badop(void);
1021 extern int afs_noop(void);
1022 extern afs_int32 afs_data_pointer_to_int32(const void *p);
1023
1024 /* afs_warn.c */
1025
1026 #ifdef AFS_AIX_ENV
1027 /* AIX doesn't have usable va_args support in its kernel */
1028 extern void afs_warn();
1029 extern void afs_warnuser();
1030 #else
1031 extern void afs_warn(char *fmt, ...)
1032         AFS_ATTRIBUTE_FORMAT(__printf__, 1, 2);
1033 extern void afs_warnuser(char *fmt, ...)
1034         AFS_ATTRIBUTE_FORMAT(__printf__, 1, 2);
1035 #endif
1036
1037 /* afs_vcache.c */
1038 extern int afs_ShakeLooseVCaches(afs_int32 anumber);
1039 extern afs_int32 afs_maxvcount;
1040 extern afs_int32 afs_vcount;
1041 extern int afsvnumbers;
1042 extern afs_rwlock_t afs_xvreclaim;
1043 extern afs_rwlock_t afs_xvcache;
1044 extern afs_rwlock_t afs_xvcdirty;
1045 extern afs_lock_t afs_xvcb;
1046 extern struct afs_q VLRU;
1047 extern afs_int32 vcachegen;
1048 extern unsigned int afs_paniconwarn;
1049 extern struct afs_q afs_vhashTV[VCSIZE];
1050 extern afs_int32 afs_bulkStatsLost;
1051 extern int afs_norefpanic;
1052 extern struct vcache *ReclaimedVCList;
1053 extern ino_t vcacheMetaInode;
1054 extern struct osi_file *afs_vcacheMetaInodep;
1055
1056 extern void afs_FlushReclaimedVcaches(void);
1057 void afs_vcacheInit(int astatSize);
1058 extern struct vcache *afs_FindVCache(struct VenusFid *afid, afs_int32 * retry,
1059                                      afs_int32 flag);
1060 extern afs_int32 afs_FetchStatus(struct vcache *avc, struct VenusFid *afid,
1061                                  struct vrequest *areq,
1062                                  struct AFSFetchStatus *Outsp);
1063
1064 extern afs_int32 afs_FlushVCBs(afs_int32 lockit);
1065 extern void afs_InactiveVCache(struct vcache *avc, afs_ucred_t *acred);
1066 extern struct vcache *afs_LookupVCache(struct VenusFid *afid,
1067                                        struct vrequest *areq,
1068                                        afs_int32 * cached, struct vcache *adp,
1069                                        char *aname);
1070 extern void afs_FlushAllVCaches(void);
1071 extern int afs_FlushVCache(struct vcache *avc, int *slept);
1072 extern struct vcache *afs_GetRootVCache(struct VenusFid *afid,
1073                                         struct vrequest *areq,
1074                                         afs_int32 * cached,
1075                                         struct volume *tvolp);
1076 extern struct vcache *afs_NewVCache(struct VenusFid *afid,
1077                                     struct server *serverp);
1078 extern struct vcache *afs_NewBulkVCache(struct VenusFid *afid,
1079                                         struct server *serverp, int seq);
1080 extern int afs_VerifyVCache2(struct vcache *avc, struct vrequest *areq);
1081 extern struct vcache *afs_GetVCache(struct VenusFid *afid,
1082                                     struct vrequest *areq, afs_int32 * cached,
1083                                     struct vcache *avc);
1084 extern void afs_PutVCache(struct vcache *avc);
1085 extern int afs_RefVCache(struct vcache *avc);
1086 extern void afs_ProcessFS(struct vcache *avc,
1087                           struct AFSFetchStatus *astat,
1088                           struct vrequest *areq);
1089 extern struct afs_cbr *afs_AllocCBR(void);
1090 extern int afs_FreeCBR(struct afs_cbr *asp);
1091 extern void afs_RemoveVCB(struct VenusFid *afid);
1092 extern void afs_FlushActiveVcaches(afs_int32 doflocks);
1093 extern int afs_WriteVCache(struct vcache *avc,
1094                            struct AFSStoreStatus *astatus,
1095                            struct vrequest *areq);
1096 extern int afs_RemoteLookup(struct VenusFid *afid,
1097                             struct vrequest *areq, char *name,
1098                             struct VenusFid *nfid,
1099                             struct AFSFetchStatus *OutStatusp,
1100                             struct AFSCallBack *CallBackp,
1101                             struct server **serverp,
1102                             struct AFSVolSync *tsyncp);
1103 extern void afs_ResetVCache(struct vcache *, afs_ucred_t *);
1104 extern afs_int32 afs_NFSFindVCache(struct vcache **avcp,
1105                                    struct VenusFid *afid);
1106 extern void afs_vcacheInit(int astatSize);
1107 extern void shutdown_vcache(void);
1108 extern void afs_DisconGiveUpCallbacks(void);
1109 extern void afs_ClearAllStatdFlag(void);
1110
1111 /* VNOPS/afs_vnop_access.c */
1112 extern afs_int32 afs_GetAccessBits(struct vcache *avc,
1113                                    afs_int32 arights,
1114                                    struct vrequest *areq);
1115 extern int afs_AccessOK(struct vcache *avc, afs_int32 arights,
1116                         struct vrequest *areq, afs_int32 check_mode_bits);
1117 #if defined(AFS_SUN5_ENV) || (defined(AFS_SGI_ENV) && !defined(AFS_SGI65_ENV))
1118 extern int afs_access(OSI_VC_DECL(avc), afs_int32 amode, int flags,
1119                       afs_ucred_t *acred);
1120 #else
1121 extern int afs_access(OSI_VC_DECL(avc), afs_int32 amode,
1122                       afs_ucred_t *acred);
1123 #endif
1124 extern int afs_getRights(OSI_VC_DECL(avc), afs_int32 arights,
1125                          afs_ucred_t *acred);
1126
1127 /* VNOPS/afs_vnop_attrs.c */
1128 extern int afs_CopyOutAttrs(struct vcache *avc,
1129                             struct vattr *attrs);
1130 #if     defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1131 extern int afs_getattr(OSI_VC_DECL(avc), struct vattr *attrs, int flags,
1132                        afs_ucred_t *acred);
1133 #else
1134 extern int afs_getattr(OSI_VC_DECL(avc), struct vattr *attrs,
1135                        afs_ucred_t *acred);
1136 #endif
1137 extern int afs_VAttrToAS(struct vcache *avc,
1138                          struct vattr *av,
1139                          struct AFSStoreStatus *as);
1140 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1141 extern int afs_setattr(OSI_VC_DECL(avc), struct vattr *attrs,
1142                        int flags, afs_ucred_t *acred);
1143 #else
1144 extern int afs_setattr(OSI_VC_DECL(avc), struct vattr *attrs,
1145                        afs_ucred_t *acred);
1146 #endif
1147
1148 /* VNOPS/afs_vnop_create.c */
1149 #ifdef AFS_SGI64_ENV
1150 extern int afs_create(OSI_VC_DECL(adp), char *aname, struct vattr *attrs,
1151                       int flags, int amode, struct vcache **avcp,
1152                       afs_ucred_t *acred);
1153 #else /* AFS_SGI64_ENV */
1154 extern int afs_create(OSI_VC_DECL(adp), char *aname, struct vattr *attrs,
1155                       enum vcexcl aexcl, int amode, struct vcache **avcp,
1156                       afs_ucred_t *acred);
1157 #endif /* AFS_SGI64_ENV */
1158 extern int afs_LocalHero(struct vcache *avc,
1159                          struct dcache *adc,
1160                          AFSFetchStatus * astat, int aincr);
1161
1162 /* VNOPS/afs_vnop_dirops.c */
1163
1164 extern int afs_mkdir(OSI_VC_DECL(adp), char *aname, struct vattr *attrs,
1165                      struct vcache **avcp, afs_ucred_t *acred);
1166 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1167 extern int afs_rmdir(OSI_VC_DECL(adp), char *aname, struct vnode *cdirp,
1168                      afs_ucred_t *acred);
1169 #else
1170 extern int afs_rmdir(OSI_VC_DECL(adp), char *aname, afs_ucred_t *acred);
1171 #endif
1172
1173 struct fid;
1174 /* VNOPS/afs_vnop_fid.c */
1175 #if !defined(AFS_ATHENA_ENV)
1176 #ifdef AFS_AIX41_ENV
1177 int afs_fid(OSI_VC_DECL(avc), struct fid *fidpp, struct ucred *credp);
1178 #elif defined(AFS_SUN54_ENV)
1179 int afs_fid(OSI_VC_DECL(avc), struct fid *fidpp);
1180 #else
1181 int afs_fid(OSI_VC_DECL(avc), struct fid **fidpp);
1182 #endif                          /* AFS_AIX41_ENV */
1183 #endif
1184
1185 /* VNOPS/afs_vnop_flock.c */
1186 extern afs_int32 lastWarnTime;
1187
1188 extern void lockIdSet(struct AFS_FLOCK *flock, struct SimpleLocks *slp,
1189                       int clid);
1190 extern int HandleFlock(struct vcache *avc, int acom,
1191                        struct vrequest *areq, pid_t clid, int onlymine);
1192
1193 #if defined(AFS_SGI_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
1194 extern int afs_lockctl(struct vcache * avc, struct AFS_FLOCK * af, int acmd,
1195                        afs_ucred_t * acred, pid_t clid);
1196 #else
1197 extern int afs_lockctl(struct vcache * avc, struct AFS_FLOCK * af, int acmd,
1198                        afs_ucred_t * acred);
1199 #endif
1200
1201 /* VNOPS/afs_vnop_link.c */
1202 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1203 extern int afs_link(OSI_VC_DECL(adp), struct vcache *avc, char *aname,
1204                     afs_ucred_t *acred);
1205 #else
1206 extern int afs_link(struct vcache *avc, OSI_VC_DECL(adp), char *aname,
1207                     afs_ucred_t *acred);
1208 #endif
1209
1210 /* VNOPS/afs_vnop_lookup.c */
1211 extern int EvalMountPoint(struct vcache *avc, struct vcache *advc,
1212                           struct volume **avolpp,
1213                           struct vrequest *areq);
1214 extern void afs_InitFakeStat(struct afs_fakestat_state *state);
1215 extern int afs_EvalFakeStat(struct vcache **avcp,
1216                             struct afs_fakestat_state *state,
1217                             struct vrequest *areq);
1218 extern int afs_TryEvalFakeStat(struct vcache **avcp,
1219                                struct afs_fakestat_state *state,
1220                                struct vrequest *areq);
1221 extern void afs_PutFakeStat(struct afs_fakestat_state *state);
1222 extern int afs_ENameOK(char *aname);
1223 extern void Check_AtSys(struct vcache *avc, const char *aname,
1224                         struct sysname_info *state, struct vrequest *areq);
1225 extern int Next_AtSys(struct vcache *avc, struct vrequest *areq,
1226                       struct sysname_info *state);
1227 extern int afs_DoBulkStat(struct vcache *adp, long dirCookie,
1228                           struct vrequest *areqp);
1229
1230 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV)
1231 extern int afs_lookup(OSI_VC_DECL(adp), char *aname, struct vcache **avcp,
1232                       struct pathname *pnp, int flags, struct vnode *rdir,
1233                       afs_ucred_t *acred);
1234 #elif defined(UKERNEL)
1235 extern int afs_lookup(OSI_VC_DECL(adp), char *aname, struct vcache **avcp,
1236                       afs_ucred_t *acred, int flags);
1237 #else
1238 extern int afs_lookup(OSI_VC_DECL(adp), char *aname, struct vcache **avcp,
1239                       afs_ucred_t *acred);
1240 #endif
1241
1242 /* VNOPS/afs_vnop_open.c */
1243 #ifdef AFS_SGI64_ENV
1244 extern int afs_open(bhv_desc_t * bhv, struct vcache **avcp, afs_int32 aflags,
1245                     afs_ucred_t *acred);
1246 #else
1247 extern int afs_open(struct vcache **avcp, afs_int32 aflags,
1248                     afs_ucred_t *acred);
1249 #endif
1250
1251
1252 /* VNOPS/afs_vnop_read.c */
1253 extern int afs_read(struct vcache *avc, struct uio *auio,
1254                     afs_ucred_t *acred, int noLock);
1255
1256 extern int afs_UFSReadUIO(afs_dcache_id_t *cacheId, struct uio *tuiop);
1257
1258 extern void afs_PrefetchChunk(struct vcache *avc, struct dcache *adc,
1259                               afs_ucred_t *acred, struct vrequest *areq);
1260
1261
1262 /* VNOPS/afs_vnop_readdir.c */
1263 extern int afs_rd_stash_i;
1264 #if defined(AFS_SUN5_ENV) || defined(AFS_SGI_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
1265 extern int afs_readdir(OSI_VC_DECL(avc), struct uio *auio,
1266                        afs_ucred_t *acred, int *eofp);
1267 #elif defined(AFS_HPUX100_ENV)
1268 extern int afs_readdir2(OSI_VC_DECL(avc), struct uio *auio,
1269                         afs_ucred_t *acred);
1270 #else
1271 extern int afs_readdir(OSI_VC_DECL(avc), struct uio *auio,
1272                        afs_ucred_t *acred);
1273 #endif
1274
1275 /* VNOPS/afs_vnop_remove.c */
1276 extern int afsremove(struct vcache *adp, struct dcache *tdc,
1277                      struct vcache *tvc, char *aname,
1278                      afs_ucred_t *acred, struct vrequest *treqp);
1279 extern int afs_remunlink(struct vcache *avc, int doit);
1280 extern int afs_remove(OSI_VC_DECL(adp), char *aname, afs_ucred_t *acred);
1281 extern char *afs_newname(void);
1282
1283 /* VNOPS/afs_vnop_rename.c */
1284 extern int afsrename(struct vcache *aodp, char *aname1, struct vcache *andp,
1285                      char *aname2, afs_ucred_t *acred,
1286                      struct vrequest *areq);
1287 #ifdef AFS_SGI_ENV
1288 extern int afs_rename(OSI_VC_DECL(aodp), char *aname1, struct vcache *andp,
1289                       char *aname2, struct pathname *npnp,
1290                       afs_ucred_t *acred);
1291 #else
1292 extern int afs_rename(OSI_VC_DECL(aodp), char *aname1, struct vcache *andp,
1293                       char *aname2, afs_ucred_t *acred);
1294 #endif
1295
1296 /* VNOPS/afs_vnop_strategy.c */
1297 #if defined(AFS_SUN5_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV)
1298 extern int afs_ustrategy(struct buf *adp, afs_ucred_t *credp);
1299 #else
1300 extern int afs_ustrategy(struct buf *adp);
1301 #endif
1302
1303 /* VNOPS/afs_vnop_symlink.c */
1304 extern int afs_MemHandleLink(struct vcache *avc,
1305                              struct vrequest *areq);
1306 extern int afs_UFSHandleLink(struct vcache *avc,
1307                              struct vrequest *areq);
1308 extern int afs_symlink(OSI_VC_DECL(adp), char *aname,
1309                        struct vattr *attrs, char *atargetName,
1310                        afs_ucred_t *acred);
1311 extern int afs_readlink(OSI_VC_DECL(avc), struct uio *auio,
1312                         afs_ucred_t *acred);
1313
1314 /* VNOPS/afs_vnop_write.c */
1315 extern int afs_write(struct vcache *avc, struct uio *auio, int aio,
1316                      afs_ucred_t *acred, int noLock);
1317
1318 extern int afs_UFSWriteUIO(struct vcache *, afs_dcache_id_t *, struct uio *);
1319
1320 extern int afs_StoreOnLastReference(struct vcache *avc,
1321                                     struct vrequest *treq);
1322 extern int afs_DoPartialWrite(struct vcache *avc,
1323                               struct vrequest *areq);
1324 extern int afs_closex(struct file *afd);
1325
1326 #ifdef AFS_SGI65_ENV
1327 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags,
1328                      lastclose_t lastclose, afs_ucred_t *acred);
1329 #elif defined(AFS_SGI64_ENV)
1330 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags,
1331                      lastclose_t lastclose, off_t offset,
1332                      afs_ucred_t *acred, struct flid *flp);
1333 #elif defined(AFS_SGI_ENV)
1334 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags,
1335                      lastclose_t lastclose, off_t offset,
1336                      afs_ucred_t *acred);
1337 #elif defined(AFS_SUN5_ENV)
1338 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags, int count,
1339                      offset_t offset, afs_ucred_t *acred);
1340 #else
1341 extern int afs_close(OSI_VC_DECL(avc), afs_int32 aflags,
1342                      afs_ucred_t *acred);
1343 #endif
1344
1345 #if defined(AFS_SGI65_ENV)
1346 extern int afs_fsync(OSI_VC_DECL(avc), int flags, afs_ucred_t *acred,
1347                      off_t start, off_t stop);
1348 #elif defined(AFS_SGI_ENV) || defined(AFS_SUN53_ENV)
1349 extern int afs_fsync(OSI_VC_DECL(avc), int flag, afs_ucred_t *acred);
1350 #else
1351 extern int afs_fsync(OSI_VC_DECL(avc), afs_ucred_t *acred);
1352 #endif
1353
1354
1355 /* afs_volume.c */
1356 extern afs_int32 afs_FVIndex;
1357 extern afs_int32 afs_volCounter;
1358 extern afs_rwlock_t afs_xvolume;
1359 extern struct volume *afs_volumes[NVOLS];
1360 extern afs_dcache_id_t volumeInode;
1361 extern struct volume *afs_FindVolume(struct VenusFid *afid,
1362                                      afs_int32 locktype);
1363 extern struct volume *afs_freeVolList;
1364 extern afs_int32 fvTable[NFENTRIES];
1365 extern void InstallVolumeEntry(struct volume *av, struct vldbentry *ve,
1366                                int acell);
1367 extern void InstallNVolumeEntry(struct volume *av, struct nvldbentry *ve,
1368                                 int acell);
1369 extern void InstallUVolumeEntry(struct volume *av, struct uvldbentry *ve,
1370                                 int acell, struct cell *tcell,
1371                                 struct vrequest *areq);
1372 extern void afs_ResetVolumeInfo(struct volume *tv);
1373 extern struct volume *afs_MemGetVolSlot(void);
1374 extern void afs_ResetVolumes(struct server *srvp);
1375 extern struct volume *afs_GetVolume(struct VenusFid *afid,
1376                                     struct vrequest *areq,
1377                                     afs_int32 locktype);
1378 extern struct volume *afs_GetVolumeByName(char *aname,
1379                                           afs_int32 acell, int agood,
1380                                           struct vrequest *areq,
1381                                           afs_int32 locktype);
1382 extern struct volume *afs_UFSGetVolSlot(void);
1383 extern void afs_CheckVolumeNames(int flags);
1384
1385 /* Prototypes for generated files that aren't really in src/afs/ */
1386
1387 /* afs_uuid.c */
1388 extern afs_int32 afs_uuid_equal(afsUUID * u1, afsUUID * u2);
1389 extern afs_int32 afs_uuid_is_nil(afsUUID * u1);
1390 extern void afs_htonuuid(afsUUID * uuidp);
1391 extern void afs_ntohuuid(afsUUID * uuidp);
1392 extern afs_int32 afs_uuid_create(afsUUID * uuid);
1393 extern u_short afs_uuid_hash(afsUUID * uuid);
1394
1395 #if defined(AFS_SUN5_ENV) || defined(AFS_LINUX20_ENV) || defined(AFS_AIX_ENV) || defined(AFS_DARWIN_ENV) || defined(AFS_XBSD_ENV) || defined(AFS_HPUX_ENV) || defined(AFS_SGI62_ENV) || defined(UKERNEL)
1396 #include "osi_prototypes.h"
1397 #endif
1398
1399 #endif /* _AFS_PROTOTYPES_H_ */