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