1 /*
2 * GPL HEADER START
3 *
4 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 only,
8 * as published by the Free Software Foundation.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License version 2 for more details (a copy is included
14 * in the LICENSE file that accompanied this code).
15 *
16 * You should have received a copy of the GNU General Public License
17 * version 2 along with this program; If not, see
18 * http://www.sun.com/software/products/lustre/docs/GPLv2.pdf
19 *
20 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
21 * CA 95054 USA or visit www.sun.com if you need additional information or
22 * have any questions.
23 *
24 * GPL HEADER END
25 */
26 /*
27 * Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved.
28 * Use is subject to license terms.
29 */
30 /*
31 * This file is part of Lustre, http://www.lustre.org/
32 * Lustre is a trademark of Sun Microsystems, Inc.
33 *
34 * libcfs/include/libcfs/libcfs_time.h
35 *
36 * Time functions.
37 *
38 */
39
40 #ifndef __LIBCFS_TIME_H__
41 #define __LIBCFS_TIME_H__
42 /*
43 * generic time manipulation functions.
44 */
45
cfs_time_add(unsigned long t,long d)46 static inline unsigned long cfs_time_add(unsigned long t, long d)
47 {
48 return (unsigned long)(t + d);
49 }
50
cfs_time_sub(unsigned long t1,unsigned long t2)51 static inline unsigned long cfs_time_sub(unsigned long t1, unsigned long t2)
52 {
53 return (unsigned long)(t1 - t2);
54 }
55
cfs_time_after(unsigned long t1,unsigned long t2)56 static inline int cfs_time_after(unsigned long t1, unsigned long t2)
57 {
58 return time_before(t2, t1);
59 }
60
cfs_time_aftereq(unsigned long t1,unsigned long t2)61 static inline int cfs_time_aftereq(unsigned long t1, unsigned long t2)
62 {
63 return time_before_eq(t2, t1);
64 }
65
cfs_time_shift(int seconds)66 static inline unsigned long cfs_time_shift(int seconds)
67 {
68 return cfs_time_add(cfs_time_current(), cfs_time_seconds(seconds));
69 }
70
71 /*
72 * return valid time-out based on user supplied one. Currently we only check
73 * that time-out is not shorted than allowed.
74 */
cfs_timeout_cap(long timeout)75 static inline long cfs_timeout_cap(long timeout)
76 {
77 if (timeout < CFS_TICK)
78 timeout = CFS_TICK;
79 return timeout;
80 }
81
82 #endif
83