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