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 void openafs_insque(struct TM_Elem *elementp, struct TM_Elem *quep);
27 void openafs_remque(struct TM_Elem *elementp);
28 extern int TM_eql(struct timeval *t1, struct timeval *t2);
31 #define Tm_Insert(list, elem) openafs_insque(list, elem)
32 #define TM_Remove(list, elem) openafs_remque(elem)
33 extern int TM_Rescan();
35 extern struct TM_Elem *TM_GetExpired();
36 extern struct TM_Elem *TM_GetEarliest();
39 extern int TM_Final();
41 #define FOR_ALL_ELTS(var, list, body)\
43 register struct TM_Elem *_LIST_, *var, *_NEXT_;\
45 for (var = _LIST_ -> Next; var != _LIST_; var = _NEXT_) {\
46 _NEXT_ = var -> Next;\