clock.c revision 1.5 1 1.5 christos /* $NetBSD: clock.c,v 1.5 2014/11/21 00:51:09 christos Exp $ */
2 1.1 cdi
3 1.1 cdi /*-
4 1.1 cdi * Copyright (c) 2003 The NetBSD Foundation, Inc.
5 1.1 cdi * All rights reserved.
6 1.1 cdi *
7 1.1 cdi * This code is derived from software contributed to The NetBSD Foundation
8 1.1 cdi * by Manuel Bouyer.
9 1.1 cdi *
10 1.1 cdi * Redistribution and use in source and binary forms, with or without
11 1.1 cdi * modification, are permitted provided that the following conditions
12 1.1 cdi * are met:
13 1.1 cdi * 1. Redistributions of source code must retain the above copyright
14 1.1 cdi * notice, this list of conditions and the following disclaimer.
15 1.1 cdi * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 cdi * notice, this list of conditions and the following disclaimer in the
17 1.1 cdi * documentation and/or other materials provided with the distribution.
18 1.1 cdi *
19 1.1 cdi * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 cdi * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 cdi * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 cdi * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 cdi * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 cdi * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 cdi * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 cdi * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 cdi * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 cdi * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 cdi * POSSIBILITY OF SUCH DAMAGE.
30 1.1 cdi */
31 1.1 cdi
32 1.2 tsutsui #include <sys/param.h>
33 1.1 cdi #include <sys/types.h>
34 1.1 cdi #include <lib/libsa/stand.h>
35 1.2 tsutsui #include <lib/libkern/libkern.h>
36 1.2 tsutsui
37 1.2 tsutsui #include <netinet/in.h>
38 1.2 tsutsui #include <netinet/in_systm.h>
39 1.2 tsutsui #include <lib/libsa/net.h>
40 1.2 tsutsui
41 1.5 christos #include <dev/clock_subr.h>
42 1.2 tsutsui #include <dev/ic/mc146818reg.h>
43 1.2 tsutsui
44 1.2 tsutsui #include <mips/cpuregs.h>
45 1.1 cdi
46 1.1 cdi #include "boot.h"
47 1.1 cdi
48 1.1 cdi #define DELAY_CALIBRATE 1000
49 1.1 cdi
50 1.2 tsutsui #define MCCLOCK_BASE 0x10000070
51 1.2 tsutsui #define MCCLOCK_REG 0
52 1.2 tsutsui #define MCCLOCK_DATA 1
53 1.2 tsutsui
54 1.1 cdi void
55 1.1 cdi delay(int ms)
56 1.1 cdi {
57 1.1 cdi /*
58 1.1 cdi * XXX need *real* clock calibration.
59 1.1 cdi */
60 1.1 cdi volatile register int N = ms * DELAY_CALIBRATE;
61 1.1 cdi for (; --N;)
62 1.2 tsutsui __insn_barrier();
63 1.2 tsutsui }
64 1.2 tsutsui
65 1.4 tsutsui satime_t
66 1.2 tsutsui getsecs(void)
67 1.2 tsutsui {
68 1.2 tsutsui volatile uint8_t *mcclock_reg, *mcclock_data;
69 1.2 tsutsui u_int sec;
70 1.2 tsutsui
71 1.2 tsutsui mcclock_reg = (void *)MIPS_PHYS_TO_KSEG1(MCCLOCK_BASE + MCCLOCK_REG);
72 1.2 tsutsui mcclock_data = (void *)MIPS_PHYS_TO_KSEG1(MCCLOCK_BASE + MCCLOCK_DATA);
73 1.2 tsutsui
74 1.2 tsutsui *mcclock_reg = MC_SEC;
75 1.2 tsutsui sec = bcdtobin(*mcclock_data);
76 1.2 tsutsui *mcclock_reg = MC_MIN;
77 1.2 tsutsui sec += bcdtobin(*mcclock_data) * 60;
78 1.2 tsutsui *mcclock_reg = MC_HOUR;
79 1.2 tsutsui sec += bcdtobin(*mcclock_data) * 60 * 60;
80 1.2 tsutsui
81 1.4 tsutsui return (satime_t)sec;
82 1.1 cdi }
83