clock.h revision 1.5 1 1.5 ragge /* $NetBSD: clock.h,v 1.5 2000/07/26 11:54:34 ragge Exp $ */
2 1.1 ragge /*
3 1.1 ragge * Copyright (c) 1996 Ludd, University of Lule}, Sweden.
4 1.1 ragge * All rights reserved.
5 1.1 ragge *
6 1.1 ragge * Redistribution and use in source and binary forms, with or without
7 1.1 ragge * modification, are permitted provided that the following conditions
8 1.1 ragge * are met:
9 1.1 ragge * 1. Redistributions of source code must retain the above copyright
10 1.1 ragge * notice, this list of conditions and the following disclaimer.
11 1.1 ragge * 2. Redistributions in binary form must reproduce the above copyright
12 1.1 ragge * notice, this list of conditions and the following disclaimer in the
13 1.1 ragge * documentation and/or other materials provided with the distribution.
14 1.1 ragge * 3. All advertising materials mentioning features or use of this software
15 1.1 ragge * must display the following acknowledgement:
16 1.1 ragge * This product includes software developed at Ludd, University of
17 1.1 ragge * Lule}, Sweden and its contributors.
18 1.1 ragge * 4. The name of the author may not be used to endorse or promote products
19 1.1 ragge * derived from this software without specific prior written permission
20 1.1 ragge *
21 1.1 ragge * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22 1.1 ragge * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23 1.1 ragge * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24 1.1 ragge * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25 1.1 ragge * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26 1.1 ragge * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 1.1 ragge * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 1.1 ragge * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 1.1 ragge * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30 1.1 ragge * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 1.1 ragge */
32 1.1 ragge
33 1.1 ragge /*
34 1.1 ragge * Time constants. These are unlikely to change.
35 1.1 ragge */
36 1.1 ragge #define IS_LEAPYEAR(y) (((y % 4) == 0) && (y % 100))
37 1.1 ragge
38 1.1 ragge #define SEC_PER_MIN (60)
39 1.1 ragge #define SEC_PER_HOUR (SEC_PER_MIN * 60)
40 1.1 ragge #define SEC_PER_DAY (SEC_PER_HOUR * 24)
41 1.1 ragge #define DAYSPERYEAR(y) (IS_LEAPYEAR(y) ? 366 : 365)
42 1.1 ragge #define SECPERYEAR(y) (DAYSPERYEAR(y) * SEC_PER_DAY)
43 1.1 ragge
44 1.1 ragge #define CLKREAD_OK 0
45 1.1 ragge #define CLKREAD_BAD -1
46 1.1 ragge #define CLKREAD_WARN -2
47 1.1 ragge
48 1.1 ragge #define TODRBASE (1 << 28) /* Rumours says it comes from VMS */
49 1.1 ragge
50 1.2 ragge #define SEC_OFF 0
51 1.2 ragge #define MIN_OFF 2
52 1.2 ragge #define HR_OFF 4
53 1.2 ragge #define WDAY_OFF 6
54 1.2 ragge #define DAY_OFF 7
55 1.2 ragge #define MON_OFF 8
56 1.2 ragge #define YR_OFF 9
57 1.2 ragge #define CSRA_OFF 10
58 1.2 ragge #define CSRB_OFF 11
59 1.2 ragge #define CSRD_OFF 13
60 1.2 ragge
61 1.2 ragge #define CSRA_UIP 0200
62 1.2 ragge #define CSRB_SET 0200
63 1.2 ragge #define CSRB_24 0002
64 1.2 ragge #define CSRB_DM 0004
65 1.2 ragge #define CSRD_VRT 0200
66 1.2 ragge
67 1.3 ragge /* Var's used when dealing with clock chip */
68 1.4 ragge extern volatile short *clk_page;
69 1.3 ragge extern int clk_adrshift, clk_tweak;
70 1.3 ragge
71 1.1 ragge /* Prototypes */
72 1.5 ragge int generic_clkread(time_t);
73 1.5 ragge void generic_clkwrite(void);
74 1.5 ragge int chip_clkread(time_t);
75 1.5 ragge void chip_clkwrite(void);
76 1.5 ragge int yeartonum(int);
77 1.5 ragge int numtoyear(int);
78