2 * Copyright 2000, International Business Machines Corporation and others.
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
10 /*******************************************************************\
12 * Information Technology Center *
13 * Carnegie-Mellon University *
16 \*******************************************************************/
19 struct TM_Elem *Next; /* filled by package */
20 struct TM_Elem *Prev; /* filled by package */
21 struct timeval TotalTime; /* filled in by caller -- modified by package */
22 struct timeval TimeLeft; /* filled by package */
23 char *BackPointer; /* filled by caller, not interpreted by package */
26 #if defined(AFS_HPUX_ENV) || defined(AFS_NT40_ENV)
27 extern void insque(struct TM_Elem *elementp, struct TM_Elem *quep);
28 extern void remque(struct TM_Elem *elementp);
29 extern int TM_eql(struct timeval *t1, struct timeval *t2);
32 #define Tm_Insert(list, elem) insque(list, elem)
33 #define TM_Remove(list, elem) remque(elem)
34 extern int TM_Rescan();
36 extern struct TM_Elem *TM_GetExpired();
37 extern struct TM_Elem *TM_GetEarliest();
40 extern int TM_Final();
42 #define FOR_ALL_ELTS(var, list, body)\
44 register struct TM_Elem *_LIST_, *var, *_NEXT_;\
46 for (var = _LIST_ -> Next; var != _LIST_; var = _NEXT_) {\
47 _NEXT_ = var -> Next;\