256382a6ba18e8beb07d798144d4d3149fec1fc0
[openafs.git] / src / xstat / xstat_cm_test.c
1 /*
2  * Copyright 2000, International Business Machines Corporation and others.
3  * All Rights Reserved.
4  *
5  * This software has been released under the terms of the IBM Public
6  * License.  For details, see the LICENSE file in the top-level source
7  * directory or online at http://www.openafs.org/dl/license10.html
8  */
9
10 /*
11  * Description:
12  *      Test of the xstat_cm module.
13  *
14  *------------------------------------------------------------------------*/
15
16 #include <afsconfig.h>
17 #include <afs/param.h>
18
19 #include <roken.h>
20
21 #include "xstat_cm.h"           /*Interface for xstat_cm module */
22 #include <afs/cmd.h>            /*Command line interpreter */
23 #include <afs/afsutil.h>
24
25 /*
26  * Command line parameter indices.
27  *      P_CM_NAMES : List of CacheManager names.
28  *      P_COLL_IDS : List of collection IDs to pick up.
29  *      P_ONESHOT  : Are we gathering exactly one round of data?
30  *      P_DEBUG    : Enable debugging output?
31  */
32 #define P_CM_NAMES      0
33 #define P_COLL_IDS      1
34 #define P_ONESHOT       2
35 #define P_FREQUENCY     3
36 #define P_PERIOD        4
37 #define P_DEBUG         5
38
39 /*
40  * Private globals.
41  */
42 static int debugging_on = 0;    /*Are we debugging? */
43 static int one_shot = 0;        /*Single round of data collection? */
44
45 static char *fsOpNames[] = {
46     "FetchData",
47     "FetchACL",
48     "FetchStatus",
49     "StoreData",
50     "StoreACL",
51     "StoreStatus",
52     "RemoveFile",
53     "CreateFile",
54     "Rename",
55     "Symlink",
56     "Link",
57     "MakeDir",
58     "RemoveDir",
59     "SetLock",
60     "ExtendLock",
61     "ReleaseLock",
62     "GetStatistics",
63     "GiveUpCallbacks",
64     "GetVolumeInfo",
65     "GetVolumeStatus",
66     "SetVolumeStatus",
67     "GetRootVolume",
68     "CheckToken",
69     "GetTime",
70     "NGetVolumeInfo",
71     "BulkStatus",
72     "XStatsVersion",
73     "GetXStats",
74     "XLookup"
75 };
76
77 static char *cmOpNames[] = {
78     "CallBack",
79     "InitCallBackState",
80     "Probe",
81     "GetLock",
82     "GetCE",
83     "XStatsVersion",
84     "GetXStats"
85 };
86
87 static char *xferOpNames[] = {
88     "FetchData",
89     "StoreData"
90 };
91
92
93 /*------------------------------------------------------------------------
94  * PrintCallInfo
95  *
96  * Description:
97  *      Print out the AFSCB_XSTATSCOLL_PERF_INFO collection we just
98  *      received.
99  *
100  * Arguments:
101  *      None.
102  *
103  * Returns:
104  *      Nothing.
105  *
106  * Environment:
107  *      All the info we need is nestled into xstat_cm_Results.
108  *
109  * Side Effects:
110  *      As advertised.
111  *------------------------------------------------------------------------*/
112
113 void
114 PrintCallInfo(void)
115 {                               /*PrintCallInfo */
116
117     int i;              /*Loop variable */
118     int numInt32s;              /*# int32words returned */
119     afs_int32 *currInt32;       /*Ptr to current afs_int32 value */
120     char *printableTime;        /*Ptr to printable time string */
121     time_t probeTime = xstat_cm_Results.probeTime;
122     /*
123      * Just print out the results of the particular probe.
124      */
125     numInt32s = xstat_cm_Results.data.AFSCB_CollData_len;
126     currInt32 = (afs_int32 *) (xstat_cm_Results.data.AFSCB_CollData_val);
127     printableTime = ctime(&probeTime);
128     printableTime[strlen(printableTime) - 1] = '\0';
129
130     printf
131         ("AFSCB_XSTATSCOLL_CALL_INFO (coll %d) for CM %s\n[Poll %u, %s]\n\n",
132          xstat_cm_Results.collectionNumber, xstat_cm_Results.connP->hostName,
133          xstat_cm_Results.probeNum, printableTime);
134
135     if (debugging_on)
136         printf("\n[%u entries returned at %" AFS_PTR_FMT "]\n\n", numInt32s, currInt32);
137
138     for (i = 0; i < numInt32s; i++)
139         printf("%u ", *currInt32++);
140     printf("\n");
141
142
143 }                               /*PrintCallInfo */
144
145 /* Print detailed functional call statistics */
146
147 void
148 print_cmCallStats(void)
149 {
150     char *printableTime;        /*Ptr to printable time string */
151     struct afs_CMStats *cmp;
152     time_t probeTime = xstat_cm_Results.probeTime;
153
154     printableTime = ctime(&probeTime);
155     printableTime[strlen(printableTime) - 1] = '\0';
156
157     printf
158         ("AFSCB_XSTATSCOLL_CALL_INFO (coll %d) for CM %s\n[Probe %u, %s]\n\n",
159          xstat_cm_Results.collectionNumber, xstat_cm_Results.connP->hostName,
160          xstat_cm_Results.probeNum, printableTime);
161
162     cmp = (struct afs_CMStats *)(xstat_cm_Results.data.AFSCB_CollData_val);
163
164     if (xstat_cm_Results.data.AFSCB_CollData_len != sizeof(struct afs_CMStats))
165         printf("Data sets differ in size. Is cache manager a different version?");
166
167     printf("\t%10u afs_init\n", cmp->callInfo.C_afs_init);
168     printf("\t%10u gop_rdwr\n", cmp->callInfo.C_gop_rdwr);
169     printf("\t%10u aix_gnode_rele\n", cmp->callInfo.C_aix_gnode_rele);
170     printf("\t%10u gettimeofday\n", cmp->callInfo.C_gettimeofday);
171     printf("\t%10u m_cpytoc\n", cmp->callInfo.C_m_cpytoc);
172     printf("\t%10u aix_vattr_null\n", cmp->callInfo.C_aix_vattr_null);
173     printf("\t%10u afs_gn_ftrunc\n", cmp->callInfo.C_afs_gn_ftrunc);
174     printf("\t%10u afs_gn_rdwr\n", cmp->callInfo.C_afs_gn_rdwr);
175     printf("\t%10u afs_gn_ioctl\n", cmp->callInfo.C_afs_gn_ioctl);
176     printf("\t%10u afs_gn_locktl\n", cmp->callInfo.C_afs_gn_lockctl);
177     printf("\t%10u afs_gn_readlink\n", cmp->callInfo.C_afs_gn_readlink);
178     printf("\t%10u afs_gn_readdir\n", cmp->callInfo.C_afs_gn_readdir);
179     printf("\t%10u afs_gn_select\n", cmp->callInfo.C_afs_gn_select);
180     printf("\t%10u afs_gn_strategy\n", cmp->callInfo.C_afs_gn_strategy);
181     printf("\t%10u afs_gn_symlink\n", cmp->callInfo.C_afs_gn_symlink);
182     printf("\t%10u afs_gn_revoke\n", cmp->callInfo.C_afs_gn_revoke);
183     printf("\t%10u afs_gn_link\n", cmp->callInfo.C_afs_gn_link);
184     printf("\t%10u afs_gn_mkdir\n", cmp->callInfo.C_afs_gn_mkdir);
185     printf("\t%10u afs_gn_mknod\n", cmp->callInfo.C_afs_gn_mknod);
186     printf("\t%10u afs_gn_remove\n", cmp->callInfo.C_afs_gn_remove);
187     printf("\t%10u afs_gn_rename\n", cmp->callInfo.C_afs_gn_rename);
188     printf("\t%10u afs_gn_rmdir\n", cmp->callInfo.C_afs_gn_rmdir);
189     printf("\t%10u afs_gn_fid\n", cmp->callInfo.C_afs_gn_fid);
190     printf("\t%10u afs_gn_lookup\n", cmp->callInfo.C_afs_gn_lookup);
191     printf("\t%10u afs_gn_open\n", cmp->callInfo.C_afs_gn_open);
192     printf("\t%10u afs_gn_create\n", cmp->callInfo.C_afs_gn_create);
193     printf("\t%10u afs_gn_hold\n", cmp->callInfo.C_afs_gn_hold);
194     printf("\t%10u afs_gn_rele\n", cmp->callInfo.C_afs_gn_rele);
195     printf("\t%10u afs_gn_unmap\n", cmp->callInfo.C_afs_gn_unmap);
196     printf("\t%10u afs_gn_access\n", cmp->callInfo.C_afs_gn_access);
197     printf("\t%10u afs_gn_getattr\n", cmp->callInfo.C_afs_gn_getattr);
198     printf("\t%10u afs_gn_setattr\n", cmp->callInfo.C_afs_gn_setattr);
199     printf("\t%10u afs_gn_fclear\n", cmp->callInfo.C_afs_gn_fclear);
200     printf("\t%10u afs_gn_fsync\n", cmp->callInfo.C_afs_gn_fsync);
201     printf("\t%10u phash\n", cmp->callInfo.C_pHash);
202     printf("\t%10u DInit\n", cmp->callInfo.C_DInit);
203     printf("\t%10u DRead\n", cmp->callInfo.C_DRead);
204     printf("\t%10u FixupBucket\n", cmp->callInfo.C_FixupBucket);
205     printf("\t%10u afs_newslot\n", cmp->callInfo.C_afs_newslot);
206     printf("\t%10u DRelease\n", cmp->callInfo.C_DRelease);
207     printf("\t%10u DFlush\n", cmp->callInfo.C_DFlush);
208     printf("\t%10u DFlushEntry\n", cmp->callInfo.C_DFlushEntry);
209     printf("\t%10u DVOffset\n", cmp->callInfo.C_DVOffset);
210     printf("\t%10u DZap\n", cmp->callInfo.C_DZap);
211     printf("\t%10u DNew\n", cmp->callInfo.C_DNew);
212     printf("\t%10u afs_RemoveVCB\n", cmp->callInfo.C_afs_RemoveVCB);
213     printf("\t%10u afs_NewVCache\n", cmp->callInfo.C_afs_NewVCache);
214     printf("\t%10u afs_FlushActiveVcaches\n",
215            cmp->callInfo.C_afs_FlushActiveVcaches);
216     printf("\t%10u afs_VerifyVCache\n", cmp->callInfo.C_afs_VerifyVCache);
217     printf("\t%10u afs_WriteVCache\n", cmp->callInfo.C_afs_WriteVCache);
218     printf("\t%10u afs_GetVCache\n", cmp->callInfo.C_afs_GetVCache);
219     printf("\t%10u afs_StuffVcache\n", cmp->callInfo.C_afs_StuffVcache);
220     printf("\t%10u afs_FindVCache\n", cmp->callInfo.C_afs_FindVCache);
221     printf("\t%10u afs_PutDCache\n", cmp->callInfo.C_afs_PutDCache);
222     printf("\t%10u afs_PutVCache\n", cmp->callInfo.C_afs_PutVCache);
223     printf("\t%10u CacheStoreProc\n", cmp->callInfo.C_CacheStoreProc);
224     printf("\t%10u afs_FindDcache\n", cmp->callInfo.C_afs_FindDCache);
225     printf("\t%10u afs_TryToSmush\n", cmp->callInfo.C_afs_TryToSmush);
226     printf("\t%10u afs_AdjustSize\n", cmp->callInfo.C_afs_AdjustSize);
227     printf("\t%10u afs_CheckSize\n", cmp->callInfo.C_afs_CheckSize);
228     printf("\t%10u afs_StoreWarn\n", cmp->callInfo.C_afs_StoreWarn);
229     printf("\t%10u CacheFetchProc\n", cmp->callInfo.C_CacheFetchProc);
230     printf("\t%10u UFS_CacheStoreProc\n", cmp->callInfo.C_UFS_CacheStoreProc);
231     printf("\t%10u UFS_CacheFetchProc\n", cmp->callInfo.C_UFS_CacheFetchProc);
232     printf("\t%10u afs_GetDCache\n", cmp->callInfo.C_afs_GetDCache);
233     printf("\t%10u afs_SimpleVStat\n", cmp->callInfo.C_afs_SimpleVStat);
234     printf("\t%10u afs_ProcessFS\n", cmp->callInfo.C_afs_ProcessFS);
235     printf("\t%10u afs_InitCacheInfo\n", cmp->callInfo.C_afs_InitCacheInfo);
236     printf("\t%10u afs_InitVolumeInfo\n", cmp->callInfo.C_afs_InitVolumeInfo);
237     printf("\t%10u afs_InitCacheFile\n", cmp->callInfo.C_afs_InitCacheFile);
238     printf("\t%10u afs_CacheInit\n", cmp->callInfo.C_afs_CacheInit);
239     printf("\t%10u afs_GetDSlot\n", cmp->callInfo.C_afs_GetDSlot);
240     printf("\t%10u afs_WriteThroughDSlots\n",
241            cmp->callInfo.C_afs_WriteThroughDSlots);
242     printf("\t%10u afs_MemGetDSlot\n", cmp->callInfo.C_afs_MemGetDSlot);
243     printf("\t%10u afs_UFSGetDSlot\n", cmp->callInfo.C_afs_UFSGetDSlot);
244     printf("\t%10u afs_StoreDCache\n", cmp->callInfo.C_afs_StoreDCache);
245     printf("\t%10u afs_StoreMini\n", cmp->callInfo.C_afs_StoreMini);
246     printf("\t%10u afs_StoreAllSegments\n",
247            cmp->callInfo.C_afs_StoreAllSegments);
248     printf("\t%10u afs_InvalidateAllSegments\n",
249            cmp->callInfo.C_afs_InvalidateAllSegments);
250     printf("\t%10u afs_TruncateAllSegments\n",
251            cmp->callInfo.C_afs_TruncateAllSegments);
252     printf("\t%10u afs_CheckVolSync\n", cmp->callInfo.C_afs_CheckVolSync);
253     printf("\t%10u afs_wakeup\n", cmp->callInfo.C_afs_wakeup);
254     printf("\t%10u afs_CFileOpen\n", cmp->callInfo.C_afs_CFileOpen);
255     printf("\t%10u afs_CFileTruncate\n", cmp->callInfo.C_afs_CFileTruncate);
256     printf("\t%10u afs_GetDownD\n", cmp->callInfo.C_afs_GetDownD);
257     printf("\t%10u afs_WriteDCache\n", cmp->callInfo.C_afs_WriteDCache);
258     printf("\t%10u afs_FlushDCache\n", cmp->callInfo.C_afs_FlushDCache);
259     printf("\t%10u afs_GetDownDSlot\n", cmp->callInfo.C_afs_GetDownDSlot);
260     printf("\t%10u afs_FlushVCache\n", cmp->callInfo.C_afs_FlushVCache);
261     printf("\t%10u afs_GetDownV\n", cmp->callInfo.C_afs_GetDownV);
262     printf("\t%10u afs_QueueVCB\n", cmp->callInfo.C_afs_QueueVCB);
263     printf("\t%10u afs_call\n", cmp->callInfo.C_afs_call);
264     printf("\t%10u afs_syscall_call\n", cmp->callInfo.C_afs_syscall_call);
265     printf("\t%10u afs_syscall_icreate\n",
266            cmp->callInfo.C_afs_syscall_icreate);
267     printf("\t%10u afs_syscall_iopen\n", cmp->callInfo.C_afs_syscall_iopen);
268     printf("\t%10u afs_syscall_iincdec\n",
269            cmp->callInfo.C_afs_syscall_iincdec);
270     printf("\t%10u afs_syscall_ireadwrite\n",
271            cmp->callInfo.C_afs_syscall_ireadwrite);
272     printf("\t%10u afs_syscall\n", cmp->callInfo.C_afs_syscall);
273     printf("\t%10u lpioctl\n", cmp->callInfo.C_lpioctl);
274     printf("\t%10u lsetpag\n", cmp->callInfo.C_lsetpag);
275     printf("\t%10u afs_CheckInit\n", cmp->callInfo.C_afs_CheckInit);
276     printf("\t%10u ClearCallback\n", cmp->callInfo.C_ClearCallBack);
277     printf("\t%10u SRXAFSCB_GetCE\n", cmp->callInfo.C_SRXAFSCB_GetCE);
278     printf("\t%10u SRXAFSCB_GetLock\n", cmp->callInfo.C_SRXAFSCB_GetLock);
279     printf("\t%10u SRXAFSCB_CallBack\n", cmp->callInfo.C_SRXAFSCB_CallBack);
280     printf("\t%10u SRXAFSCB_InitCallBackState\n",
281            cmp->callInfo.C_SRXAFSCB_InitCallBackState);
282     printf("\t%10u SRXAFSCB_Probe\n", cmp->callInfo.C_SRXAFSCB_Probe);
283     printf("\t%10u afs_Chunk\n", cmp->callInfo.C_afs_Chunk);
284     printf("\t%10u afs_ChunkBase\n", cmp->callInfo.C_afs_ChunkBase);
285     printf("\t%10u afs_ChunkOffset\n", cmp->callInfo.C_afs_ChunkOffset);
286     printf("\t%10u afs_ChunkSize\n", cmp->callInfo.C_afs_ChunkSize);
287     printf("\t%10u afs_ChunkToBase\n", cmp->callInfo.C_afs_ChunkToBase);
288     printf("\t%10u afs_ChunkToSize\n", cmp->callInfo.C_afs_ChunkToSize);
289     printf("\t%10u afs_SetChunkSize\n", cmp->callInfo.C_afs_SetChunkSize);
290     printf("\t%10u afs_config\n", cmp->callInfo.C_afs_config);
291     printf("\t%10u mem_freebytes\n", cmp->callInfo.C_mem_freebytes);
292     printf("\t%10u mem_getbytes\n", cmp->callInfo.C_mem_getbytes);
293     printf("\t%10u afs_Daemon\n", cmp->callInfo.C_afs_Daemon);
294     printf("\t%10u afs_CheckRootVolume\n",
295            cmp->callInfo.C_afs_CheckRootVolume);
296     printf("\t%10u BPath\n", cmp->callInfo.C_BPath);
297     printf("\t%10u BPrefetch\n", cmp->callInfo.C_BPrefetch);
298     printf("\t%10u BStore\n", cmp->callInfo.C_BStore);
299     printf("\t%10u afs_BBusy\n", cmp->callInfo.C_afs_BBusy);
300     printf("\t%10u afs_BQueue\n", cmp->callInfo.C_afs_BQueue);
301     printf("\t%10u afs_BRelease\n", cmp->callInfo.C_afs_BRelease);
302     printf("\t%10u afs_BackgroundDaemon\n",
303            cmp->callInfo.C_afs_BackgroundDaemon);
304     printf("\t%10u exporter_add\n", cmp->callInfo.C_exporter_add);
305     printf("\t%10u exporter_find\n", cmp->callInfo.C_exporter_find);
306     printf("\t%10u afs_gfs_kalloc\n", cmp->callInfo.C_afs_gfs_kalloc);
307     printf("\t%10u afs_gfs_kfree\n", cmp->callInfo.C_afs_gfs_kfree);
308     printf("\t%10u gop_lookupname\n", cmp->callInfo.C_gop_lookupname);
309     printf("\t%10u afs_uniqtime\n", cmp->callInfo.C_afs_uniqtime);
310     printf("\t%10u gfs_vattr_null\n", cmp->callInfo.C_gfs_vattr_null);
311     printf("\t%10u afs_lock\n", cmp->callInfo.C_afs_lock);
312     printf("\t%10u afs_unlock\n", cmp->callInfo.C_afs_unlock);
313     printf("\t%10u afs_update\n", cmp->callInfo.C_afs_update);
314     printf("\t%10u afs_gclose\n", cmp->callInfo.C_afs_gclose);
315     printf("\t%10u afs_gopen\n", cmp->callInfo.C_afs_gopen);
316     printf("\t%10u afs_greadlink\n", cmp->callInfo.C_afs_greadlink);
317     printf("\t%10u afs_select\n", cmp->callInfo.C_afs_select);
318     printf("\t%10u afs_gbmap\n", cmp->callInfo.C_afs_gbmap);
319     printf("\t%10u afs_getfsdata\n", cmp->callInfo.C_afs_getfsdata);
320     printf("\t%10u afs_gsymlink\n", cmp->callInfo.C_afs_gsymlink);
321     printf("\t%10u afs_namei\n", cmp->callInfo.C_afs_namei);
322     printf("\t%10u afs_gmount\n", cmp->callInfo.C_afs_gmount);
323     printf("\t%10u afs_gget\n", cmp->callInfo.C_afs_gget);
324     printf("\t%10u afs_glink\n", cmp->callInfo.C_afs_glink);
325     printf("\t%10u afs_gmkdir\n", cmp->callInfo.C_afs_gmkdir);
326     printf("\t%10u afs_unlink\n", cmp->callInfo.C_afs_unlink);
327     printf("\t%10u afs_grmdir\n", cmp->callInfo.C_afs_grmdir);
328     printf("\t%10u afs_makenode\n", cmp->callInfo.C_afs_makenode);
329     printf("\t%10u afs_grename\n", cmp->callInfo.C_afs_grename);
330     printf("\t%10u afs_rele\n", cmp->callInfo.C_afs_rele);
331     printf("\t%10u afs_syncgp\n", cmp->callInfo.C_afs_syncgp);
332     printf("\t%10u afs_getval\n", cmp->callInfo.C_afs_getval);
333     printf("\t%10u afs_trunc\n", cmp->callInfo.C_afs_trunc);
334     printf("\t%10u afs_rwgp\n", cmp->callInfo.C_afs_rwgp);
335     printf("\t%10u afs_stat\n", cmp->callInfo.C_afs_stat);
336     printf("\t%10u afsc_link\n", cmp->callInfo.C_afsc_link);
337     printf("\t%10u afs_vfs_mount\n", cmp->callInfo.C_afs_vfs_mount);
338     printf("\t%10u afs_uniqtime\n", cmp->callInfo.C_afs_uniqtime);
339     printf("\t%10u iopen\n", cmp->callInfo.C_iopen);
340     printf("\t%10u idec\n", cmp->callInfo.C_idec);
341     printf("\t%10u iinc\n", cmp->callInfo.C_iinc);
342     printf("\t%10u ireadwrite\n", cmp->callInfo.C_ireadwrite);
343     printf("\t%10u iread\n", cmp->callInfo.C_iread);
344     printf("\t%10u iwrite\n", cmp->callInfo.C_iwrite);
345     printf("\t%10u iforget\n", cmp->callInfo.C_iforget);
346     printf("\t%10u icreate\n", cmp->callInfo.C_icreate);
347     printf("\t%10u igetinode\n", cmp->callInfo.C_igetinode);
348     printf("\t%10u osi_SleepR\n", cmp->callInfo.C_osi_SleepR);
349     printf("\t%10u osi_SleepS\n", cmp->callInfo.C_osi_SleepS);
350     printf("\t%10u osi_SleepW\n", cmp->callInfo.C_osi_SleepW);
351     printf("\t%10u osi_Sleep\n", cmp->callInfo.C_osi_Sleep);
352     printf("\t%10u afs_LookupMCE\n", cmp->callInfo.C_afs_LookupMCE);
353     printf("\t%10u afs_MemReadBlk\n", cmp->callInfo.C_afs_MemReadBlk);
354     printf("\t%10u afs_MemReadUIO\n", cmp->callInfo.C_afs_MemReadUIO);
355     printf("\t%10u afs_MemWriteBlk\n", cmp->callInfo.C_afs_MemWriteBlk);
356     printf("\t%10u afs_MemWriteUIO\n", cmp->callInfo.C_afs_MemWriteUIO);
357     printf("\t%10u afs_MemCacheStoreProc\n",
358            cmp->callInfo.C_afs_MemCacheStoreProc);
359     printf("\t%10u afs_MemCacheFetchProc\n",
360            cmp->callInfo.C_afs_MemCacheFetchProc);
361     printf("\t%10u afs_MemCacheTruncate\n",
362            cmp->callInfo.C_afs_MemCacheTruncate);
363     printf("\t%10u afs_MemCacheStoreProc\n",
364            cmp->callInfo.C_afs_MemCacheStoreProc);
365     printf("\t%10u afs_GetNfsClientPag\n",
366            cmp->callInfo.C_afs_GetNfsClientPag);
367     printf("\t%10u afs_FindNfsClientPag\n",
368            cmp->callInfo.C_afs_FindNfsClientPag);
369     printf("\t%10u afs_PutNfsClientPag\n",
370            cmp->callInfo.C_afs_PutNfsClientPag);
371     printf("\t%10u afs_nfsclient_reqhandler\n",
372            cmp->callInfo.C_afs_nfsclient_reqhandler);
373     printf("\t%10u afs_nfsclient_GC\n", cmp->callInfo.C_afs_nfsclient_GC);
374     printf("\t%10u afs_nfsclient_hold\n", cmp->callInfo.C_afs_nfsclient_hold);
375     printf("\t%10u afs_nfsclient_stats\n",
376            cmp->callInfo.C_afs_nfsclient_stats);
377     printf("\t%10u afs_nfsclient_sysname\n",
378            cmp->callInfo.C_afs_nfsclient_sysname);
379     printf("\t%10u afs_rfs_dispatch\n", cmp->callInfo.C_afs_rfs_dispatch);
380     printf("\t%10u afs_nfs2afscall\n", cmp->callInfo.C_Nfs2AfsCall);
381     printf("\t%10u afs_sun_xuntext\n", cmp->callInfo.C_afs_sun_xuntext);
382     printf("\t%10u osi_Active\n", cmp->callInfo.C_osi_Active);
383     printf("\t%10u osi_FlushPages\n", cmp->callInfo.C_osi_FlushPages);
384     printf("\t%10u osi_FlushText\n", cmp->callInfo.C_osi_FlushText);
385     printf("\t%10u osi_CallProc\n", cmp->callInfo.C_osi_CallProc);
386     printf("\t%10u osi_CancelProc\n", cmp->callInfo.C_osi_CancelProc);
387     printf("\t%10u osi_Invisible\n", cmp->callInfo.C_osi_Invisible);
388     printf("\t%10u osi_Time\n", cmp->callInfo.C_osi_Time);
389     printf("\t%10u osi_Alloc\n", cmp->callInfo.C_osi_Alloc);
390     printf("\t%10u osi_SetTime\n", cmp->callInfo.C_osi_SetTime);
391     printf("\t%10u osi_Dump\n", cmp->callInfo.C_osi_Dump);
392     printf("\t%10u osi_Free\n", cmp->callInfo.C_osi_Free);
393     printf("\t%10u osi_UFSOpen\n", cmp->callInfo.C_osi_UFSOpen);
394     printf("\t%10u osi_Close\n", cmp->callInfo.C_osi_Close);
395     printf("\t%10u osi_Stat\n", cmp->callInfo.C_osi_Stat);
396     printf("\t%10u osi_Truncate\n", cmp->callInfo.C_osi_Truncate);
397     printf("\t%10u osi_Read\n", cmp->callInfo.C_osi_Read);
398     printf("\t%10u osi_Write\n", cmp->callInfo.C_osi_Write);
399     printf("\t%10u osi_MapStrategy\n", cmp->callInfo.C_osi_MapStrategy);
400     printf("\t%10u osi_AllocLargeSpace\n",
401            cmp->callInfo.C_osi_AllocLargeSpace);
402     printf("\t%10u osi_FreeLargeSpace\n", cmp->callInfo.C_osi_FreeLargeSpace);
403     printf("\t%10u osi_AllocSmallSpace\n",
404            cmp->callInfo.C_osi_AllocSmallSpace);
405     printf("\t%10u osi_FreeSmallSpace\n", cmp->callInfo.C_osi_FreeSmallSpace);
406     printf("\t%10u osi_CloseToTheEdge\n", cmp->callInfo.C_osi_CloseToTheEdge);
407     printf("\t%10u osi_xgreedy\n", cmp->callInfo.C_osi_xgreedy);
408     printf("\t%10u osi_FreeSocket\n", cmp->callInfo.C_osi_FreeSocket);
409     printf("\t%10u osi_NewSocket\n", cmp->callInfo.C_osi_NewSocket);
410     printf("\t%10u osi_NetSend\n", cmp->callInfo.C_osi_NetSend);
411     printf("\t%10u WaitHack\n", cmp->callInfo.C_WaitHack);
412     printf("\t%10u osi_CancelWait\n", cmp->callInfo.C_osi_CancelWait);
413     printf("\t%10u osi_Wakeup\n", cmp->callInfo.C_osi_Wakeup);
414     printf("\t%10u osi_Wait\n", cmp->callInfo.C_osi_Wait);
415     printf("\t%10u dirp_Read\n", cmp->callInfo.C_dirp_Read);
416     printf("\t%10u dirp_Cpy\n", cmp->callInfo.C_dirp_Cpy);
417     printf("\t%10u dirp_Eq\n", cmp->callInfo.C_dirp_Eq);
418     printf("\t%10u dirp_Write\n", cmp->callInfo.C_dirp_Write);
419     printf("\t%10u dirp_Zap\n", cmp->callInfo.C_dirp_Zap);
420     printf("\t%10u afs_ioctl\n", cmp->callInfo.C_afs_ioctl);
421     printf("\t%10u handleIoctl\n", cmp->callInfo.C_HandleIoctl);
422     printf("\t%10u afs_xioctl\n", cmp->callInfo.C_afs_xioctl);
423     printf("\t%10u afs_pioctl\n", cmp->callInfo.C_afs_pioctl);
424     printf("\t%10u HandlePioctl\n", cmp->callInfo.C_HandlePioctl);
425     printf("\t%10u PGetVolumeStatus\n", cmp->callInfo.C_PGetVolumeStatus);
426     printf("\t%10u PSetVolumeStatus\n", cmp->callInfo.C_PSetVolumeStatus);
427     printf("\t%10u PFlush\n", cmp->callInfo.C_PFlush);
428     printf("\t%10u PFlushVolumeData\n", cmp->callInfo.C_PFlushVolumeData);
429     printf("\t%10u PNewStatMount\n", cmp->callInfo.C_PNewStatMount);
430     printf("\t%10u PGetTokens\n", cmp->callInfo.C_PGetTokens);
431     printf("\t%10u PSetTokens\n", cmp->callInfo.C_PSetTokens);
432     printf("\t%10u PUnlog\n", cmp->callInfo.C_PUnlog);
433     printf("\t%10u PCheckServers\n", cmp->callInfo.C_PCheckServers);
434     printf("\t%10u PCheckAuth\n", cmp->callInfo.C_PCheckAuth);
435     printf("\t%10u PCheckVolNames\n", cmp->callInfo.C_PCheckVolNames);
436     printf("\t%10u PFindVolume\n", cmp->callInfo.C_PFindVolume);
437     printf("\t%10u Prefetch\n", cmp->callInfo.C_Prefetch);
438     printf("\t%10u PGetCacheSize\n", cmp->callInfo.C_PGetCacheSize);
439     printf("\t%10u PSetCacheSize\n", cmp->callInfo.C_PSetCacheSize);
440     printf("\t%10u PSetSysName\n", cmp->callInfo.C_PSetSysName);
441     printf("\t%10u PExportAfs\n", cmp->callInfo.C_PExportAfs);
442     printf("\t%10u HandleClientContext\n",
443            cmp->callInfo.C_HandleClientContext);
444     printf("\t%10u PViceAccess\n", cmp->callInfo.C_PViceAccess);
445     printf("\t%10u PRemoveCallBack\n", cmp->callInfo.C_PRemoveCallBack);
446     printf("\t%10u PRemoveMount\n", cmp->callInfo.C_PRemoveMount);
447     printf("\t%10u PSetVolumeStatus\n", cmp->callInfo.C_PSetVolumeStatus);
448     printf("\t%10u PListCells\n", cmp->callInfo.C_PListCells);
449     printf("\t%10u PNewCell\n", cmp->callInfo.C_PNewCell);
450     printf("\t%10u PGetUserCell\n", cmp->callInfo.C_PGetUserCell);
451     printf("\t%10u PGetCellStatus\n", cmp->callInfo.C_PGetCellStatus);
452     printf("\t%10u PSetCellStatus\n", cmp->callInfo.C_PSetCellStatus);
453     printf("\t%10u PVenusLogging\n", cmp->callInfo.C_PVenusLogging);
454     printf("\t%10u PGetAcl\n", cmp->callInfo.C_PGetAcl);
455     printf("\t%10u PGetFID\n", cmp->callInfo.C_PGetFID);
456     printf("\t%10u PSetAcl\n", cmp->callInfo.C_PSetAcl);
457     printf("\t%10u PGetFileCell\n", cmp->callInfo.C_PGetFileCell);
458     printf("\t%10u PGetWSCell\n", cmp->callInfo.C_PGetWSCell);
459     printf("\t%10u PGetSPrefs\n", cmp->callInfo.C_PGetSPrefs);
460     printf("\t%10u PSetSPrefs\n", cmp->callInfo.C_PSetSPrefs);
461     printf("\t%10u afs_ResetAccessCache\n",
462            cmp->callInfo.C_afs_ResetAccessCache);
463     printf("\t%10u afs_FindUser\n", cmp->callInfo.C_afs_FindUser);
464     printf("\t%10u afs_GetUser\n", cmp->callInfo.C_afs_GetUser);
465     printf("\t%10u afs_GCUserData\n", cmp->callInfo.C_afs_GCUserData);
466     printf("\t%10u afs_PutUser\n", cmp->callInfo.C_afs_PutUser);
467     printf("\t%10u afs_SetPrimary\n", cmp->callInfo.C_afs_SetPrimary);
468     printf("\t%10u afs_ResetUserConns\n", cmp->callInfo.C_afs_ResetUserConns);
469     printf("\t%10u afs_RemoveUserConns\n", cmp->callInfo.C_RemoveUserConns);
470     printf("\t%10u afs_ResourceInit\n", cmp->callInfo.C_afs_ResourceInit);
471     printf("\t%10u afs_GetCell\n", cmp->callInfo.C_afs_GetCell);
472     printf("\t%10u afs_GetCellByIndex\n", cmp->callInfo.C_afs_GetCellByIndex);
473     printf("\t%10u afs_GetCellByName\n", cmp->callInfo.C_afs_GetCellByName);
474     printf("\t%10u afs_GetRealCellByIndex\n",
475            cmp->callInfo.C_afs_GetRealCellByIndex);
476     printf("\t%10u afs_NewCell\n", cmp->callInfo.C_afs_NewCell);
477     printf("\t%10u CheckVLDB\n", cmp->callInfo.C_CheckVLDB);
478     printf("\t%10u afs_GetVolume\n", cmp->callInfo.C_afs_GetVolume);
479     printf("\t%10u afs_PutVolume\n", cmp->callInfo.C_afs_PutVolume);
480     printf("\t%10u afs_GetVolumeByName\n",
481            cmp->callInfo.C_afs_GetVolumeByName);
482     printf("\t%10u afs_random\n", cmp->callInfo.C_afs_random);
483     printf("\t%10u InstallVolumeEntry\n", cmp->callInfo.C_InstallVolumeEntry);
484     printf("\t%10u InstallVolumeInfo\n", cmp->callInfo.C_InstallVolumeInfo);
485     printf("\t%10u afs_ResetVolumeInfo\n",
486            cmp->callInfo.C_afs_ResetVolumeInfo);
487     printf("\t%10u afs_FindServer\n", cmp->callInfo.C_afs_FindServer);
488     printf("\t%10u afs_GetServer\n", cmp->callInfo.C_afs_GetServer);
489     printf("\t%10u afs_SortServers\n", cmp->callInfo.C_afs_SortServers);
490     printf("\t%10u afs_CheckServers\n", cmp->callInfo.C_afs_CheckServers);
491     printf("\t%10u ServerDown\n", cmp->callInfo.C_ServerDown);
492     printf("\t%10u afs_Conn\n", cmp->callInfo.C_afs_Conn);
493     printf("\t%10u afs_PutConn\n", cmp->callInfo.C_afs_PutConn);
494     printf("\t%10u afs_ConnByHost\n", cmp->callInfo.C_afs_ConnByHost);
495     printf("\t%10u afs_ConnByMHosts\n", cmp->callInfo.C_afs_ConnByMHosts);
496     printf("\t%10u afs_Analyze\n", cmp->callInfo.C_afs_Analyze);
497     printf("\t%10u afs_CheckLocks\n", cmp->callInfo.C_afs_CheckLocks);
498     printf("\t%10u CheckVLServer\n", cmp->callInfo.C_CheckVLServer);
499     printf("\t%10u afs_CheckCacheResets\n",
500            cmp->callInfo.C_afs_CheckCacheResets);
501     printf("\t%10u afs_CheckVolumeNames\n",
502            cmp->callInfo.C_afs_CheckVolumeNames);
503     printf("\t%10u afs_CheckCode\n", cmp->callInfo.C_afs_CheckCode);
504     printf("\t%10u afs_CopyError\n", cmp->callInfo.C_afs_CopyError);
505     printf("\t%10u afs_FinalizeReq\n", cmp->callInfo.C_afs_FinalizeReq);
506     printf("\t%10u afs_GetVolCache\n", cmp->callInfo.C_afs_GetVolCache);
507     printf("\t%10u afs_GetVolSlot\n", cmp->callInfo.C_afs_GetVolSlot);
508     printf("\t%10u afs_UFSGetVolSlot\n", cmp->callInfo.C_afs_UFSGetVolSlot);
509     printf("\t%10u afs_MemGetVolSlot\n", cmp->callInfo.C_afs_MemGetVolSlot);
510     printf("\t%10u afs_WriteVolCache\n", cmp->callInfo.C_afs_WriteVolCache);
511     printf("\t%10u haveCallbacksfrom\n", cmp->callInfo.C_HaveCallBacksFrom);
512     printf("\t%10u afs_getpage\n", cmp->callInfo.C_afs_getpage);
513     printf("\t%10u afs_putpage\n", cmp->callInfo.C_afs_putpage);
514     printf("\t%10u afs_nfsrdwr\n", cmp->callInfo.C_afs_nfsrdwr);
515     printf("\t%10u afs_map\n", cmp->callInfo.C_afs_map);
516     printf("\t%10u afs_cmp\n", cmp->callInfo.C_afs_cmp);
517     printf("\t%10u afs_PageLeft\n", cmp->callInfo.C_afs_PageLeft);
518     printf("\t%10u afs_mount\n", cmp->callInfo.C_afs_mount);
519     printf("\t%10u afs_unmount\n", cmp->callInfo.C_afs_unmount);
520     printf("\t%10u afs_root\n", cmp->callInfo.C_afs_root);
521     printf("\t%10u afs_statfs\n", cmp->callInfo.C_afs_statfs);
522     printf("\t%10u afs_sync\n", cmp->callInfo.C_afs_sync);
523     printf("\t%10u afs_vget\n", cmp->callInfo.C_afs_vget);
524     printf("\t%10u afs_index\n", cmp->callInfo.C_afs_index);
525     printf("\t%10u afs_setpag\n", cmp->callInfo.C_afs_setpag);
526     printf("\t%10u genpag\n", cmp->callInfo.C_genpag);
527     printf("\t%10u getpag\n", cmp->callInfo.C_getpag);
528     printf("\t%10u genpag\n", cmp->callInfo.C_genpag);
529     printf("\t%10u afs_GetMariner\n", cmp->callInfo.C_afs_GetMariner);
530     printf("\t%10u afs_AddMarinerName\n", cmp->callInfo.C_afs_AddMarinerName);
531     printf("\t%10u afs_open\n", cmp->callInfo.C_afs_open);
532     printf("\t%10u afs_close\n", cmp->callInfo.C_afs_close);
533     printf("\t%10u afs_closex\n", cmp->callInfo.C_afs_closex);
534     printf("\t%10u afs_write\n", cmp->callInfo.C_afs_write);
535     printf("\t%10u afs_UFSwrite\n", cmp->callInfo.C_afs_UFSWrite);
536     printf("\t%10u afs_Memwrite\n", cmp->callInfo.C_afs_MemWrite);
537     printf("\t%10u afs_rdwr\n", cmp->callInfo.C_afs_rdwr);
538     printf("\t%10u afs_read\n", cmp->callInfo.C_afs_read);
539     printf("\t%10u afs_UFSread\n", cmp->callInfo.C_afs_UFSRead);
540     printf("\t%10u afs_Memread\n", cmp->callInfo.C_afs_MemRead);
541     printf("\t%10u afs_CopyOutAttrs\n", cmp->callInfo.C_afs_CopyOutAttrs);
542     printf("\t%10u afs_access\n", cmp->callInfo.C_afs_access);
543     printf("\t%10u afs_getattr\n", cmp->callInfo.C_afs_getattr);
544     printf("\t%10u afs_setattr\n", cmp->callInfo.C_afs_setattr);
545     printf("\t%10u afs_VAttrToAS\n", cmp->callInfo.C_afs_VAttrToAS);
546     printf("\t%10u EvalMountPoint\n", cmp->callInfo.C_EvalMountPoint);
547     printf("\t%10u afs_lookup\n", cmp->callInfo.C_afs_lookup);
548     printf("\t%10u afs_create\n", cmp->callInfo.C_afs_create);
549     printf("\t%10u afs_LocalHero\n", cmp->callInfo.C_afs_LocalHero);
550     printf("\t%10u afs_remove\n", cmp->callInfo.C_afs_remove);
551     printf("\t%10u afs_link\n", cmp->callInfo.C_afs_link);
552     printf("\t%10u afs_rename\n", cmp->callInfo.C_afs_rename);
553     printf("\t%10u afs_InitReq\n", cmp->callInfo.C_afs_InitReq);
554     printf("\t%10u afs_mkdir\n", cmp->callInfo.C_afs_mkdir);
555     printf("\t%10u afs_rmdir\n", cmp->callInfo.C_afs_rmdir);
556     printf("\t%10u afs_readdir\n", cmp->callInfo.C_afs_readdir);
557     printf("\t%10u afs_read1dir\n", cmp->callInfo.C_afs_read1dir);
558     printf("\t%10u afs_readdir_move\n", cmp->callInfo.C_afs_readdir_move);
559     printf("\t%10u afs_readdir_iter\n", cmp->callInfo.C_afs_readdir_iter);
560     printf("\t%10u afs_symlink\n", cmp->callInfo.C_afs_symlink);
561     printf("\t%10u afs_HandleLink\n", cmp->callInfo.C_afs_HandleLink);
562     printf("\t%10u afs_MemHandleLink\n", cmp->callInfo.C_afs_MemHandleLink);
563     printf("\t%10u afs_UFSHandleLink\n", cmp->callInfo.C_afs_UFSHandleLink);
564     printf("\t%10u HandleFlock\n", cmp->callInfo.C_HandleFlock);
565     printf("\t%10u afs_readlink\n", cmp->callInfo.C_afs_readlink);
566     printf("\t%10u afs_fsync\n", cmp->callInfo.C_afs_fsync);
567     printf("\t%10u afs_inactive\n", cmp->callInfo.C_afs_inactive);
568     printf("\t%10u afs_ustrategy\n", cmp->callInfo.C_afs_ustrategy);
569     printf("\t%10u afs_strategy\n", cmp->callInfo.C_afs_strategy);
570     printf("\t%10u afs_bread\n", cmp->callInfo.C_afs_bread);
571     printf("\t%10u afs_brelse\n", cmp->callInfo.C_afs_brelse);
572     printf("\t%10u afs_bmap\n", cmp->callInfo.C_afs_bmap);
573     printf("\t%10u afs_fid\n", cmp->callInfo.C_afs_fid);
574     printf("\t%10u afs_FakeOpen\n", cmp->callInfo.C_afs_FakeOpen);
575     printf("\t%10u afs_FakeClose\n", cmp->callInfo.C_afs_FakeClose);
576     printf("\t%10u afs_StoreOnLastReference\n",
577            cmp->callInfo.C_afs_StoreOnLastReference);
578     printf("\t%10u afs_AccessOK\n", cmp->callInfo.C_afs_AccessOK);
579     printf("\t%10u afs_GetAccessBits\n", cmp->callInfo.C_afs_GetAccessBits);
580     printf("\t%10u afsio_copy\n", cmp->callInfo.C_afsio_copy);
581     printf("\t%10u afsio_trim\n", cmp->callInfo.C_afsio_trim);
582     printf("\t%10u afsio_skip\n", cmp->callInfo.C_afsio_skip);
583     printf("\t%10u afs_page_read\n", cmp->callInfo.C_afs_page_read);
584     printf("\t%10u afs_page_write\n", cmp->callInfo.C_afs_page_write);
585     printf("\t%10u afs_page_read\n", cmp->callInfo.C_afs_page_read);
586     printf("\t%10u afs_get_groups_from_pag\n",
587            cmp->callInfo.C_afs_get_groups_from_pag);
588     printf("\t%10u afs_get_pag_from_groups\n",
589            cmp->callInfo.C_afs_get_pag_from_groups);
590     printf("\t%10u AddPag\n", cmp->callInfo.C_AddPag);
591     printf("\t%10u PagInCred\n", cmp->callInfo.C_PagInCred);
592     printf("\t%10u afs_getgroups\n", cmp->callInfo.C_afs_getgroups);
593     printf("\t%10u afs_page_in\n", cmp->callInfo.C_afs_page_in);
594     printf("\t%10u afs_page_out\n", cmp->callInfo.C_afs_page_out);
595     printf("\t%10u afs_AdvanceFD\n", cmp->callInfo.C_afs_AdvanceFD);
596     printf("\t%10u afs_lockf\n", cmp->callInfo.C_afs_lockf);
597     printf("\t%10u afs_xsetgroups\n", cmp->callInfo.C_afs_xsetgroups);
598     printf("\t%10u afs_nlinks\n", cmp->callInfo.C_afs_nlinks);
599     printf("\t%10u afs_lockctl\n", cmp->callInfo.C_afs_lockctl);
600     printf("\t%10u afs_xflock\n", cmp->callInfo.C_afs_xflock);
601     printf("\t%10u PGetCPrefs\n", cmp->callInfo.C_PGetCPrefs);
602     printf("\t%10u PSetCPrefs\n", cmp->callInfo.C_PSetCPrefs);
603 #ifdef  AFS_HPUX_ENV
604     printf("\t%10u afs_pagein\n", cmp->callInfo.C_afs_pagein);
605     printf("\t%10u afs_pageout\n", cmp->callInfo.C_afs_pageout);
606     printf("\t%10u afs_hp_strategy\n", cmp->callInfo.C_afs_hp_strategy);
607 #endif
608     printf("\t%10u PFlushMount\n", cmp->callInfo.C_PFlushMount);
609     printf("\t%10u SRXAFSCB_GetServerPrefs\n",
610            cmp->callInfo.C_SRXAFSCB_GetServerPrefs);
611     printf("\t%10u SRXAFSCB_GetCellServDB\n",
612            cmp->callInfo.C_SRXAFSCB_GetCellServDB);
613     printf("\t%10u SRXAFSCB_GetLocalCell\n",
614            cmp->callInfo.C_SRXAFSCB_GetLocalCell);
615     printf("\t%10u afs_MarshallCacheConfig\n",
616            cmp->callInfo.C_afs_MarshallCacheConfig);
617     printf("\t%10u SRXAFSCB_GetCacheConfig\n",
618            cmp->callInfo.C_SRXAFSCB_GetCacheConfig);
619     printf("\t%10u SRXAFSCB_GetCE64\n", cmp->callInfo.C_SRXAFSCB_GetCE64);
620     printf("\t%10u SRXAFSCB_GetCellByNum\n",
621            cmp->callInfo.C_SRXAFSCB_GetCellByNum);
622     printf("\t%10u BPrefetchNoCache\n", cmp->callInfo.C_BPrefetchNoCache);
623     printf("\t%10u afs_ReadNoCache\n", cmp->callInfo.C_afs_ReadNoCache);
624 }
625
626
627 /*------------------------------------------------------------------------
628  * PrintUpDownStats
629  *
630  * Description:
631  *      Print the up/downtime stats for the given class of server records
632  *      provided.
633  *
634  * Arguments:
635  *      a_upDownP : Ptr to the server up/down info.
636  *
637  * Returns:
638  *      Nothing.
639  *
640  * Environment:
641  *      Nothing interesting.
642  *
643  * Side Effects:
644  *      As advertised.
645  *------------------------------------------------------------------------*/
646
647 void
648 PrintUpDownStats(struct afs_stats_SrvUpDownInfo *a_upDownP)
649 {                               /*PrintUpDownStats */
650
651     /*
652      * First, print the simple values.
653      */
654     printf("\t\t%10u numTtlRecords\n", a_upDownP->numTtlRecords);
655     printf("\t\t%10u numUpRecords\n", a_upDownP->numUpRecords);
656     printf("\t\t%10u numDownRecords\n", a_upDownP->numDownRecords);
657     printf("\t\t%10u sumOfRecordAges\n", a_upDownP->sumOfRecordAges);
658     printf("\t\t%10u ageOfYoungestRecord\n", a_upDownP->ageOfYoungestRecord);
659     printf("\t\t%10u ageOfOldestRecord\n", a_upDownP->ageOfOldestRecord);
660     printf("\t\t%10u numDowntimeIncidents\n",
661            a_upDownP->numDowntimeIncidents);
662     printf("\t\t%10u numRecordsNeverDown\n", a_upDownP->numRecordsNeverDown);
663     printf("\t\t%10u maxDowntimesInARecord\n",
664            a_upDownP->maxDowntimesInARecord);
665     printf("\t\t%10u sumOfDowntimes\n", a_upDownP->sumOfDowntimes);
666     printf("\t\t%10u shortestDowntime\n", a_upDownP->shortestDowntime);
667     printf("\t\t%10u longestDowntime\n", a_upDownP->longestDowntime);
668
669     /*
670      * Now, print the array values.
671      */
672     printf("\t\tDowntime duration distribution:\n");
673     printf("\t\t\t%8u: 0 min .. 10 min\n", a_upDownP->downDurations[0]);
674     printf("\t\t\t%8u: 10 min .. 30 min\n", a_upDownP->downDurations[1]);
675     printf("\t\t\t%8u: 30 min .. 1 hr\n", a_upDownP->downDurations[2]);
676     printf("\t\t\t%8u: 1 hr .. 2 hr\n", a_upDownP->downDurations[3]);
677     printf("\t\t\t%8u: 2 hr .. 4 hr\n", a_upDownP->downDurations[4]);
678     printf("\t\t\t%8u: 4 hr .. 8 hr\n", a_upDownP->downDurations[5]);
679     printf("\t\t\t%8u: > 8 hr\n", a_upDownP->downDurations[6]);
680
681     printf("\t\tDowntime incident distribution:\n");
682     printf("\t\t\t%8u: 0 times\n", a_upDownP->downIncidents[0]);
683     printf("\t\t\t%8u: 1 time\n", a_upDownP->downIncidents[1]);
684     printf("\t\t\t%8u: 2 .. 5 times\n", a_upDownP->downIncidents[2]);
685     printf("\t\t\t%8u: 6 .. 10 times\n", a_upDownP->downIncidents[3]);
686     printf("\t\t\t%8u: 10 .. 50 times\n", a_upDownP->downIncidents[4]);
687     printf("\t\t\t%8u: > 50 times\n", a_upDownP->downIncidents[5]);
688
689 }                               /*PrintUpDownStats */
690
691
692 /*------------------------------------------------------------------------
693  * PrintOverallPerfInfo
694  *
695  * Description:
696  *      Print out overall performance numbers.
697  *
698  * Arguments:
699  *      a_ovP : Ptr to the overall performance numbers.
700  *
701  * Returns:
702  *      Nothing.
703  *
704  * Environment:
705  *      All the info we need is nestled into xstat_cm_Results.
706  *
707  * Side Effects:
708  *      As advertised.
709  *------------------------------------------------------------------------*/
710
711 void
712 PrintOverallPerfInfo(struct afs_stats_CMPerf *a_ovP)
713 {                               /*PrintOverallPerfInfo */
714
715     printf("\t%10u numPerfCalls\n", a_ovP->numPerfCalls);
716
717     printf("\t%10u epoch\n", a_ovP->epoch);
718     printf("\t%10u numCellsVisible\n", a_ovP->numCellsVisible);
719     printf("\t%10u numCellsContacted\n", a_ovP->numCellsContacted);
720     printf("\t%10u dlocalAccesses\n", a_ovP->dlocalAccesses);
721     printf("\t%10u vlocalAccesses\n", a_ovP->vlocalAccesses);
722     printf("\t%10u dremoteAccesses\n", a_ovP->dremoteAccesses);
723     printf("\t%10u vremoteAccesses\n", a_ovP->vremoteAccesses);
724     printf("\t%10u cacheNumEntries\n", a_ovP->cacheNumEntries);
725     printf("\t%10u cacheBlocksTotal\n", a_ovP->cacheBlocksTotal);
726     printf("\t%10u cacheBlocksInUse\n", a_ovP->cacheBlocksInUse);
727     printf("\t%10u cacheBlocksOrig\n", a_ovP->cacheBlocksOrig);
728     printf("\t%10u cacheMaxDirtyChunks\n", a_ovP->cacheMaxDirtyChunks);
729     printf("\t%10u cacheCurrDirtyChunks\n", a_ovP->cacheCurrDirtyChunks);
730     printf("\t%10u dcacheHits\n", a_ovP->dcacheHits);
731     printf("\t%10u vcacheHits\n", a_ovP->vcacheHits);
732     printf("\t%10u dcacheMisses\n", a_ovP->dcacheMisses);
733     printf("\t%10u vcacheMisses\n", a_ovP->vcacheMisses);
734     printf("\t%10u cacheFilesReused\n", a_ovP->cacheFilesReused);
735     printf("\t%10u vcacheXAllocs\n", a_ovP->vcacheXAllocs);
736     printf("\t%10u dcacheXAllocs\n", a_ovP->dcacheXAllocs);
737
738     printf("\t%10u bufAlloced\n", a_ovP->bufAlloced);
739     printf("\t%10u bufHits\n", a_ovP->bufHits);
740     printf("\t%10u bufMisses\n", a_ovP->bufMisses);
741     printf("\t%10u bufFlushDirty\n", a_ovP->bufFlushDirty);
742
743     printf("\t%10u LargeBlocksActive\n", a_ovP->LargeBlocksActive);
744     printf("\t%10u LargeBlocksAlloced\n", a_ovP->LargeBlocksAlloced);
745     printf("\t%10u SmallBlocksActive\n", a_ovP->SmallBlocksActive);
746     printf("\t%10u SmallBlocksAlloced\n", a_ovP->SmallBlocksAlloced);
747     printf("\t%10u OutStandingMemUsage\n", a_ovP->OutStandingMemUsage);
748     printf("\t%10u OutStandingAllocs\n", a_ovP->OutStandingAllocs);
749     printf("\t%10u CallBackAlloced\n", a_ovP->CallBackAlloced);
750     printf("\t%10u CallBackFlushes\n", a_ovP->CallBackFlushes);
751     printf("\t%10u CallBackLoops\n", a_ovP->cbloops);
752
753     printf("\t%10u srvRecords\n", a_ovP->srvRecords);
754     printf("\t%10u srvNumBuckets\n", a_ovP->srvNumBuckets);
755     printf("\t%10u srvMaxChainLength\n", a_ovP->srvMaxChainLength);
756     printf("\t%10u srvMaxChainLengthHWM\n", a_ovP->srvMaxChainLengthHWM);
757     printf("\t%10u srvRecordsHWM\n", a_ovP->srvRecordsHWM);
758
759     printf("\t%10u cacheBucket0_Discarded\n",  a_ovP->cacheBucket0_Discarded);
760     printf("\t%10u cacheBucket1_Discarded\n",  a_ovP->cacheBucket1_Discarded);
761     printf("\t%10u cacheBucket2_Discarded\n",  a_ovP->cacheBucket2_Discarded);
762
763     printf("\t%10u sysName_ID\n", a_ovP->sysName_ID);
764
765     printf("\tFile Server up/downtimes, same cell:\n");
766     PrintUpDownStats(&(a_ovP->fs_UpDown[0]));
767
768     printf("\tFile Server up/downtimes, diff cell:\n");
769     PrintUpDownStats(&(a_ovP->fs_UpDown[1]));
770
771     printf("\tVL Server up/downtimes, same cell:\n");
772     PrintUpDownStats(&(a_ovP->vl_UpDown[0]));
773
774     printf("\tVL Server up/downtimes, diff cell:\n");
775     PrintUpDownStats(&(a_ovP->vl_UpDown[1]));
776
777 }                               /*PrintOverallPerfInfo */
778
779
780 /*------------------------------------------------------------------------
781  * PrintPerfInfo
782  *
783  * Description:
784  *      Print out the AFSCB_XSTATSCOLL_PERF_INFO collection we just
785  *      received.
786  *
787  * Arguments:
788  *      None.
789  *
790  * Returns:
791  *      Nothing.
792  *
793  * Environment:
794  *      All the info we need is nestled into xstat_cm_Results.
795  *
796  * Side Effects:
797  *      As advertised.
798  *------------------------------------------------------------------------*/
799
800 void
801 PrintPerfInfo(void)
802 {                               /*PrintPerfInfo */
803
804     static afs_int32 perfInt32s = (sizeof(struct afs_stats_CMPerf) >> 2);       /*Correct # int32s to rcv */
805     afs_int32 numInt32s;        /*# int32words received */
806     struct afs_stats_CMPerf *perfP;     /*Ptr to performance stats */
807     char *printableTime;        /*Ptr to printable time string */
808     time_t probeTime = xstat_cm_Results.probeTime;
809
810     numInt32s = xstat_cm_Results.data.AFSCB_CollData_len;
811     if (numInt32s != perfInt32s) {
812         printf("** Data size mismatch in performance collection!");
813         printf("** Expecting %u, got %u\n", perfInt32s, numInt32s);
814         printf("** Version mismatch with Cache Manager\n");
815         return;
816     }
817
818     printableTime = ctime(&probeTime);
819     printableTime[strlen(printableTime) - 1] = '\0';
820     perfP = (struct afs_stats_CMPerf *)
821         (xstat_cm_Results.data.AFSCB_CollData_val);
822
823     printf
824         ("AFSCB_XSTATSCOLL_PERF_INFO (coll %d) for CM %s\n[Probe %u, %s]\n\n",
825          xstat_cm_Results.collectionNumber, xstat_cm_Results.connP->hostName,
826          xstat_cm_Results.probeNum, printableTime);
827
828     PrintOverallPerfInfo(perfP);
829
830 }                               /*PrintPerfInfo */
831
832
833 /*------------------------------------------------------------------------
834  * PrintOpTiming
835  *
836  * Description:
837  *      Print out the contents of an FS RPC op timing structure.
838  *
839  * Arguments:
840  *      a_opIdx   : Index of the AFS operation we're printing number on.
841  *      a_opNames : Ptr to table of operaton names.
842  *      a_opTimeP : Ptr to the op timing structure to print.
843  *
844  * Returns:
845  *      Nothing.
846  *
847  * Environment:
848  *      Nothing interesting.
849  *
850  * Side Effects:
851  *      As advertised.
852  *------------------------------------------------------------------------*/
853
854 void
855 PrintOpTiming(int a_opIdx, char *a_opNames[],
856               struct afs_stats_opTimingData *a_opTimeP)
857 {                               /*PrintOpTiming */
858
859     printf
860         ("%15s: %u ops (%u OK); sum=%lu.%06lu, sqr=%lu.%06lu, min=%lu.%06lu, max=%lu.%06lu\n",
861          a_opNames[a_opIdx], a_opTimeP->numOps, a_opTimeP->numSuccesses,
862          (long)a_opTimeP->sumTime.tv_sec, (long)a_opTimeP->sumTime.tv_usec,
863          (long)a_opTimeP->sqrTime.tv_sec, (long)a_opTimeP->sqrTime.tv_usec,
864          (long)a_opTimeP->minTime.tv_sec, (long)a_opTimeP->minTime.tv_usec,
865          (long)a_opTimeP->maxTime.tv_sec, (long)a_opTimeP->maxTime.tv_usec);
866
867 }                               /*PrintOpTiming */
868
869
870 /*------------------------------------------------------------------------
871  * PrintXferTiming
872  *
873  * Description:
874  *      Print out the contents of a data transfer structure.
875  *
876  * Arguments:
877  *      a_opIdx : Index of the AFS operation we're printing number on.
878  *      a_opNames : Ptr to table of operation names.
879  *      a_xferP : Ptr to the data transfer structure to print.
880  *
881  * Returns:
882  *      Nothing.
883  *
884  * Environment:
885  *      Nothing interesting.
886  *
887  * Side Effects:
888  *      As advertised.
889  *------------------------------------------------------------------------*/
890
891 void
892 PrintXferTiming(int a_opIdx, char *a_opNames[],
893                 struct afs_stats_xferData *a_xferP)
894 {                               /*PrintXferTiming */
895
896     printf
897         ("%s: %u xfers (%u OK), time sum=%lu.%06lu, sqr=%lu.%06lu, min=%lu.%06lu, max=%lu.%06lu\n",
898          a_opNames[a_opIdx], a_xferP->numXfers, a_xferP->numSuccesses,
899          (long)a_xferP->sumTime.tv_sec, (long)a_xferP->sumTime.tv_usec,
900          (long)a_xferP->sqrTime.tv_sec, (long)a_xferP->sqrTime.tv_usec,
901          (long)a_xferP->minTime.tv_sec, (long)a_xferP->minTime.tv_usec,
902          (long)a_xferP->maxTime.tv_sec, (long)a_xferP->maxTime.tv_usec);
903     printf("\t[bytes: sum=%u, min=%u, max=%u]\n", a_xferP->sumBytes,
904            a_xferP->minBytes, a_xferP->maxBytes);
905     printf
906         ("\t[buckets: 0: %u, 1: %u, 2: %u, 3: %u, 4: %u, 5: %u, 6: %u, 7: %u, 8: %u]\n",
907          a_xferP->count[0], a_xferP->count[1], a_xferP->count[2],
908          a_xferP->count[3], a_xferP->count[4], a_xferP->count[5],
909          a_xferP->count[6], a_xferP->count[7], a_xferP->count[8]);
910
911
912 }                               /*PrintXferTiming */
913
914
915 /*------------------------------------------------------------------------
916  * PrintErrInfo
917  *
918  * Description:
919  *      Print out the contents of an FS RPC error info structure.
920  *
921  * Arguments:
922  *      a_opIdx   : Index of the AFS operation we're printing.
923  *      a_opNames : Ptr to table of operation names.
924  *      a_opErrP  : Ptr to the op timing structure to print.
925  *
926  * Returns:
927  *      Nothing.
928  *
929  * Environment:
930  *      Nothing interesting.
931  *
932  * Side Effects:
933  *      As advertised.
934  *------------------------------------------------------------------------*/
935
936 void
937 PrintErrInfo(int a_opIdx, char *a_opNames[],
938              struct afs_stats_RPCErrors *a_opErrP)
939 {                               /*PrintErrInfo */
940
941     printf
942         ("%15s: %u server, %u network, %u prot, %u vol, %u busies, %u other\n",
943          a_opNames[a_opIdx], a_opErrP->err_Server, a_opErrP->err_Network,
944          a_opErrP->err_Protection, a_opErrP->err_Volume,
945          a_opErrP->err_VolumeBusies, a_opErrP->err_Other);
946
947 }                               /*PrintErrInfo */
948
949
950 /*------------------------------------------------------------------------
951  * PrintRPCPerfInfo
952  *
953  * Description:
954  *      Print out a set of RPC performance numbers.
955  *
956  * Arguments:
957  *      a_rpcP : Ptr to RPC perf numbers to print.
958  *
959  * Returns:
960  *      Nothing.
961  *
962  * Environment:
963  *      Nothing interesting.
964  *
965  * Side Effects:
966  *      As advertised.
967  *------------------------------------------------------------------------*/
968
969 void
970 PrintRPCPerfInfo(struct afs_stats_RPCOpInfo *a_rpcP)
971 {                               /*PrintRPCPerfInfo */
972
973     int currIdx;                /*Loop variable */
974
975     /*
976      * Print the contents of each of the opcode-related arrays.
977      */
978     printf("FS Operation Timings:\n---------------------\n");
979     for (currIdx = 0; currIdx < AFS_STATS_NUM_FS_RPC_OPS; currIdx++)
980         PrintOpTiming(currIdx, fsOpNames, &(a_rpcP->fsRPCTimes[currIdx]));
981
982     printf("\nError Info:\n-----------\n");
983     for (currIdx = 0; currIdx < AFS_STATS_NUM_FS_RPC_OPS; currIdx++)
984         PrintErrInfo(currIdx, fsOpNames, &(a_rpcP->fsRPCErrors[currIdx]));
985
986     printf("\nTransfer timings:\n-----------------\n");
987     for (currIdx = 0; currIdx < AFS_STATS_NUM_FS_XFER_OPS; currIdx++)
988         PrintXferTiming(currIdx, xferOpNames,
989                         &(a_rpcP->fsXferTimes[currIdx]));
990
991     printf("\nCM Operation Timings:\n---------------------\n");
992     for (currIdx = 0; currIdx < AFS_STATS_NUM_CM_RPC_OPS; currIdx++)
993         PrintOpTiming(currIdx, cmOpNames, &(a_rpcP->cmRPCTimes[currIdx]));
994
995 }                               /*PrintRPCPerfInfo */
996
997
998 /*------------------------------------------------------------------------
999  * PrintFullPerfInfo
1000  *
1001  * Description:
1002  *      Print out a set of full performance numbers.
1003  *
1004  * Arguments:
1005  *      None.
1006  *
1007  * Returns:
1008  *      Nothing.
1009  *
1010  * Environment:
1011  *      Nothing interesting.
1012  *
1013  * Side Effects:
1014  *      As advertised.
1015  *------------------------------------------------------------------------*/
1016
1017 void
1018 PrintFullPerfInfo(void)
1019 {                               /*PrintFullPerfInfo */
1020
1021     struct afs_stats_AuthentInfo *authentP;     /*Ptr to authentication stats */
1022     struct afs_stats_AccessInfo *accessinfP;    /*Ptr to access stats */
1023     static afs_int32 fullPerfInt32s = (sizeof(struct afs_stats_CMFullPerf) >> 2);       /*Correct #int32s */
1024     afs_int32 numInt32s;        /*# int32s actually received */
1025     struct afs_stats_CMFullPerf *fullP; /*Ptr to full perf info */
1026
1027     char *printableTime;        /*Ptr to printable time string */
1028     time_t probeTime = xstat_cm_Results.probeTime;
1029
1030     numInt32s = xstat_cm_Results.data.AFSCB_CollData_len;
1031     if (numInt32s != fullPerfInt32s) {
1032         printf("** Data size mismatch in performance collection!");
1033         printf("** Expecting %u, got %u\n", fullPerfInt32s, numInt32s);
1034         printf("** Version mismatch with Cache Manager\n");
1035         return;
1036     }
1037
1038     printableTime = ctime(&probeTime);
1039     printableTime[strlen(printableTime) - 1] = '\0';
1040     fullP = (struct afs_stats_CMFullPerf *)
1041         (xstat_cm_Results.data.AFSCB_CollData_val);
1042
1043     printf
1044         ("AFSCB_XSTATSCOLL_FULL_PERF_INFO (coll %d) for CM %s\n[Probe %u, %s]\n\n",
1045          xstat_cm_Results.collectionNumber, xstat_cm_Results.connP->hostName,
1046          xstat_cm_Results.probeNum, printableTime);
1047
1048     /*
1049      * Print the overall numbers first, followed by all of the RPC numbers,
1050      * then each of the other groupings.
1051      */
1052     printf("Overall Performance Info:\n-------------------------\n");
1053     PrintOverallPerfInfo(&(fullP->perf));
1054     printf("\n");
1055     PrintRPCPerfInfo(&(fullP->rpc));
1056
1057     authentP = &(fullP->authent);
1058     printf("\nAuthentication info:\n--------------------\n");
1059     printf
1060         ("\t%u PAGS, %u records (%u auth, %u unauth), %u max in PAG, chain max: %u\n",
1061          authentP->curr_PAGs, authentP->curr_Records,
1062          authentP->curr_AuthRecords, authentP->curr_UnauthRecords,
1063          authentP->curr_MaxRecordsInPAG, authentP->curr_LongestChain);
1064     printf("\t%u PAG creations, %u tkt updates\n", authentP->PAGCreations,
1065            authentP->TicketUpdates);
1066     printf("\t[HWMs: %u PAGS, %u records, %u max in PAG, chain max: %u]\n",
1067            authentP->HWM_PAGs, authentP->HWM_Records,
1068            authentP->HWM_MaxRecordsInPAG, authentP->HWM_LongestChain);
1069
1070     accessinfP = &(fullP->accessinf);
1071     printf("\n[Un]replicated accesses:\n------------------------\n");
1072     printf
1073         ("\t%u unrep, %u rep, %u reps accessed, %u max reps/ref, %u first OK\n\n",
1074          accessinfP->unreplicatedRefs, accessinfP->replicatedRefs,
1075          accessinfP->numReplicasAccessed, accessinfP->maxReplicasPerRef,
1076          accessinfP->refFirstReplicaOK);
1077
1078     /* There really isn't any authorship info
1079      * authorP = &(fullP->author); */
1080
1081 }                               /*PrintFullPerfInfo */
1082
1083
1084 /*------------------------------------------------------------------------
1085  * CM_Handler
1086  *
1087  * Description:
1088  *      Handler routine passed to the xstat_cm module.  This handler is
1089  *      called immediately after a poll of one of the Cache Managers has
1090  *      taken place.  All it needs to know is exported by the xstat_cm
1091  *      module, namely the data structure where the probe results are
1092  *      stored.
1093  *
1094  * Arguments:
1095  *      None.
1096  *
1097  * Returns:
1098  *      0 on success,
1099  *      -1 otherwise.
1100  *
1101  * Environment:
1102  *      See above.  All we do now is print out what we got.
1103  *
1104  * Side Effects:
1105  *      As advertised.
1106  *------------------------------------------------------------------------*/
1107
1108 int
1109 CM_Handler(void)
1110 {                               /*CM_Handler */
1111
1112     static char rn[] = "CM_Handler";    /*Routine name */
1113
1114     printf("\n-----------------------------------------------------------\n");
1115
1116     /*
1117      * If the probe failed, there isn't much we can do except gripe.
1118      */
1119     if (xstat_cm_Results.probeOK) {
1120         printf("%s: Probe %u, collection %d to CM on '%s' failed, code=%d\n",
1121                rn, xstat_cm_Results.probeNum,
1122                xstat_cm_Results.collectionNumber,
1123                xstat_cm_Results.connP->hostName, xstat_cm_Results.probeOK);
1124         return (0);
1125     }
1126
1127     switch (xstat_cm_Results.collectionNumber) {
1128     case AFSCB_XSTATSCOLL_CALL_INFO:
1129         /* Why was this commented out in 3.3 ? */
1130         /* PrintCallInfo();  */
1131         print_cmCallStats();
1132         break;
1133
1134     case AFSCB_XSTATSCOLL_PERF_INFO:
1135         /* we will do nothing here */
1136         /* PrintPerfInfo(); */
1137         break;
1138
1139     case AFSCB_XSTATSCOLL_FULL_PERF_INFO:
1140         PrintFullPerfInfo();
1141         break;
1142
1143     default:
1144         printf("** Unknown collection: %d\n",
1145                xstat_cm_Results.collectionNumber);
1146     }
1147
1148     /*
1149      * Return the happy news.
1150      */
1151     return (0);
1152
1153 }                               /*CM_Handler */
1154
1155
1156 /*------------------------------------------------------------------------
1157  * CountListItems
1158  *
1159  * Description:
1160  *      Given a pointer to the list of Cache Managers we'll be polling
1161  *      (or, in fact, any list at all), compute the length of the list.
1162  *
1163  * Arguments:
1164  *      struct cmd_item *a_firstItem : Ptr to first item in list.
1165  *
1166  * Returns:
1167  *      Length of the above list.
1168  *
1169  * Environment:
1170  *      Nothing interesting.
1171  *
1172  * Side Effects:
1173  *      As advertised.
1174  *------------------------------------------------------------------------*/
1175
1176 static int
1177 CountListItems(struct cmd_item *a_firstItem)
1178 {                               /*CountListItems */
1179
1180     int list_len;               /*List length */
1181     struct cmd_item *curr_item; /*Ptr to current item */
1182
1183     list_len = 0;
1184     curr_item = a_firstItem;
1185
1186     /*
1187      * Count 'em up.
1188      */
1189     while (curr_item) {
1190         list_len++;
1191         curr_item = curr_item->next;
1192     }
1193
1194     /*
1195      * Return our tally.
1196      */
1197     return (list_len);
1198
1199 }                               /*CountListItems */
1200
1201
1202 /*------------------------------------------------------------------------
1203  * RunTheTest
1204  *
1205  * Description:
1206  *      Routine called by the command line interpreter to execute the
1207  *      meat of the program.  We count the number of Cache Managers
1208  *      to watch, allocate enough space to remember all the connection
1209  *      info for them, then go for it.
1210  *
1211  *
1212  * Arguments:
1213  *      a_s : Ptr to the command line syntax descriptor.
1214  *
1215  * Returns:
1216  *      0, but may exit the whole program on an error!
1217  *
1218  * Environment:
1219  *      Nothing interesting.
1220  *
1221  * Side Effects:
1222  *      As advertised.
1223  *------------------------------------------------------------------------*/
1224
1225 int
1226 RunTheTest(struct cmd_syndesc *a_s, void *arock)
1227 {                               /*RunTheTest */
1228
1229     static char rn[] = "RunTheTest";    /*Routine name */
1230     int code;                   /*Return code */
1231     int numCMs;                 /*# Cache Managers to monitor */
1232     int numCollIDs;             /*# collections to fetch */
1233     int currCM;                 /*Loop index */
1234     int currCollIDIdx;          /*Index of current collection ID */
1235     afs_int32 *collIDP;         /*Ptr to array of collection IDs */
1236     afs_int32 *currCollIDP;     /*Ptr to current collection ID */
1237     struct cmd_item *curr_item; /*Current CM cmd line record */
1238     struct sockaddr_in *CMSktArray;     /*Cache Manager socket array */
1239     struct hostent *he;         /*Host entry */
1240     struct timeval tv;          /*Time structure */
1241     int sleep_secs;             /*Number of seconds to sleep */
1242     int initFlags;              /*Flags passed to the init fcn */
1243     int waitCode;               /*Result of LWP_WaitProcess() */
1244     int freq;                   /*Frequency of polls */
1245     int period;                 /*Time in minutes of data collection */
1246
1247     /*
1248      * Are we doing one-shot measurements?
1249      */
1250     if (a_s->parms[P_ONESHOT].items != 0)
1251         one_shot = 1;
1252
1253     /*
1254      * Are we doing debugging output?
1255      */
1256     if (a_s->parms[P_DEBUG].items != 0)
1257         debugging_on = 1;
1258
1259     /*
1260      * Pull out the number of Cache Managers to watch and the number of
1261      * collections to get.
1262      */
1263     numCMs = CountListItems(a_s->parms[P_CM_NAMES].items);
1264     numCollIDs = CountListItems(a_s->parms[P_COLL_IDS].items);
1265
1266     /* Get the polling frequency */
1267     if (a_s->parms[P_FREQUENCY].items != 0)
1268         freq = atoi(a_s->parms[P_FREQUENCY].items->data);
1269     else
1270         freq = 30;              /* default to 30 seconds */
1271
1272     /* Get the time duration to run the tests */
1273     if (a_s->parms[P_PERIOD].items != 0)
1274         period = atoi(a_s->parms[P_PERIOD].items->data);
1275     else
1276         period = 10;            /* default to 10 minutes */
1277
1278     /*
1279      * Allocate the socket array.
1280      */
1281     if (debugging_on)
1282         printf("%s: Allocating socket array for %d Cache Manager(s)\n", rn,
1283                numCMs);
1284     CMSktArray = (struct sockaddr_in *)
1285         malloc(numCMs * sizeof(struct sockaddr_in));
1286     if (CMSktArray == (struct sockaddr_in *)0) {
1287         printf("%s: Can't allocate socket array for %d Cache Managers\n", rn,
1288                numCMs);
1289         exit(1);
1290     }
1291
1292     /*
1293      * Fill in the socket array for each of the Cache Managers listed.
1294      */
1295     curr_item = a_s->parms[P_CM_NAMES].items;
1296     for (currCM = 0; currCM < numCMs; currCM++) {
1297         CMSktArray[currCM].sin_family = AF_INET;
1298         CMSktArray[currCM].sin_port = htons(7001);      /* Cache Manager port */
1299         he = hostutil_GetHostByName(curr_item->data);
1300         if (he == NULL) {
1301             fprintf(stderr, "[%s] Can't get host info for '%s'\n", rn,
1302                     curr_item->data);
1303             exit(-1);
1304         }
1305         memcpy(&(CMSktArray[currCM].sin_addr.s_addr), he->h_addr, 4);
1306
1307         /*
1308          * Move to the next CM name.
1309          */
1310         curr_item = curr_item->next;
1311
1312     }                           /*Get socket info for each Cache Manager */
1313
1314     /*
1315      * Create and fill up the array of desired collection IDs.
1316      */
1317     if (debugging_on)
1318         printf("Allocating %d long(s) for coll ID\n", numCollIDs);
1319     collIDP = (afs_int32 *) (malloc(numCollIDs * sizeof(afs_int32)));
1320     currCollIDP = collIDP;
1321     curr_item = a_s->parms[P_COLL_IDS].items;
1322     for (currCollIDIdx = 0; currCollIDIdx < numCollIDs; currCollIDIdx++) {
1323         *currCollIDP = (afs_int32) (atoi(curr_item->data));
1324         if (debugging_on)
1325             printf("CollID at index %d is %d\n", currCollIDIdx, *currCollIDP);
1326         curr_item = curr_item->next;
1327         currCollIDP++;
1328     };
1329
1330     /*
1331      * Crank up the Cache Manager prober, then sit back and have fun.
1332      */
1333     printf("\nStarting up the xstat_cm service, ");
1334     initFlags = 0;
1335     if (debugging_on) {
1336         initFlags |= XSTAT_CM_INITFLAG_DEBUGGING;
1337         printf("debugging enabled, ");
1338     } else
1339         printf("no debugging, ");
1340     if (one_shot) {
1341         initFlags |= XSTAT_CM_INITFLAG_ONE_SHOT;
1342         printf("one-shot operation\n");
1343     } else
1344         printf("continuous operation\n");
1345
1346     code = xstat_cm_Init(numCMs,        /*Num CMs */
1347                          CMSktArray,    /*File Server socket array */
1348                          freq,  /*Probe every 30 seconds */
1349                          CM_Handler,    /*Handler routine */
1350                          initFlags,     /*Initialization flags */
1351                          numCollIDs,    /*Number of collection IDs */
1352                          collIDP);      /*Ptr to collection ID array */
1353     if (code) {
1354         fprintf(stderr, "[%s] Error returned by xstat_cm_Init: %d\n", rn,
1355                 code);
1356         xstat_cm_Cleanup(1);    /*Get rid of malloc'ed structures */
1357         exit(-1);
1358     }
1359
1360     if (one_shot) {
1361         /*
1362          * One-shot operation; just wait for the collection to be done.
1363          */
1364         if (debugging_on)
1365             printf("[%s] Calling LWP_WaitProcess() on event %" AFS_PTR_FMT
1366                    "\n", rn, &terminationEvent);
1367         waitCode = LWP_WaitProcess(&terminationEvent);
1368         if (debugging_on)
1369             printf("[%s] Returned from LWP_WaitProcess()\n", rn);
1370         if (waitCode) {
1371             if (debugging_on)
1372                 fprintf(stderr,
1373                         "[%s] Error %d encountered by LWP_WaitProcess()\n",
1374                         rn, waitCode);
1375         }
1376     } else {
1377         /*
1378          * Continuous operation.
1379          */
1380         sleep_secs = 60 * period;       /*length of data collection */
1381         printf
1382             ("xstat_cm service started, main thread sleeping for %d secs.\n",
1383              sleep_secs);
1384
1385         /*
1386          * Let's just fall asleep for a while, then we'll clean up.
1387          */
1388         tv.tv_sec = sleep_secs;
1389         tv.tv_usec = 0;
1390         code = IOMGR_Select(0,  /*Num fds */
1391                             0,  /*Descriptors ready for reading */
1392                             0,  /*Descriptors ready for writing */
1393                             0,  /*Descriptors with exceptional conditions */
1394                             &tv);       /*Timeout structure */
1395         if (code) {
1396             fprintf(stderr,
1397                     "[%s] IOMGR_Select() returned non-zero value: %d\n", rn,
1398                     code);
1399         }
1400     }
1401
1402     /*
1403      * We're all done.  Clean up, put the last nail in Rx, then
1404      * exit happily.
1405      */
1406     if (debugging_on)
1407         printf("\nYawn, main thread just woke up.  Cleaning things out...\n");
1408     code = xstat_cm_Cleanup(1); /*Get rid of malloc'ed data */
1409     rx_Finalize();
1410     return (0);
1411
1412 }                               /*RunTheTest */
1413
1414
1415 #include "AFS_component_version_number.c"
1416 int
1417 main(int argc, char **argv)
1418 {                               /*Main routine */
1419
1420     static char rn[] = "xstat_cm_test"; /*Routine name */
1421     afs_int32 code;     /*Return code */
1422     struct cmd_syndesc *ts;     /*Ptr to cmd line syntax desc */
1423
1424     /*
1425      * Set up the commands we understand.
1426      */
1427     ts = cmd_CreateSyntax("initcmd", RunTheTest, NULL, "initialize the program");
1428     cmd_AddParm(ts, "-cmname", CMD_LIST, CMD_REQUIRED,
1429                 "Cache Manager name(s) to monitor");
1430     cmd_AddParm(ts, "-collID", CMD_LIST, CMD_REQUIRED,
1431                 "Collection(s) to fetch");
1432     cmd_AddParm(ts, "-onceonly", CMD_FLAG, CMD_OPTIONAL,
1433                 "Collect results exactly once, then quit");
1434     cmd_AddParm(ts, "-frequency", CMD_SINGLE, CMD_OPTIONAL,
1435                 "poll frequency, in seconds");
1436     cmd_AddParm(ts, "-period", CMD_SINGLE, CMD_OPTIONAL,
1437                 "data collection time, in minutes");
1438     cmd_AddParm(ts, "-debug", CMD_FLAG, CMD_OPTIONAL,
1439                 "turn on debugging output");
1440
1441     /*
1442      * Parse command-line switches & execute the test, then get the
1443      * heck out of here.
1444      */
1445     code = cmd_Dispatch(argc, argv);
1446     if (code) {
1447         fprintf(stderr, "[%s] Call to cmd_Dispatch() failed; code is %d\n",
1448                 rn, code);
1449     }
1450
1451     exit(code);
1452
1453 }                               /*Main routine */