clock.c revision 1.9
11.9Stsutsui/*	$NetBSD: clock.c,v 1.9 2009/01/12 11:32:44 tsutsui Exp $ */
21.1Schuck
31.1Schuck#include <sys/types.h>
41.2Schuck#include <machine/prom.h>
51.1Schuck
61.6Sjunyoung#include <lib/libsa/stand.h>
71.9Stsutsui#include <lib/libsa/net.h>
81.2Schuck#include "libsa.h"
91.1Schuck
101.1Schuck/*
111.1Schuck * BCD to decimal and decimal to BCD.
121.1Schuck */
131.3Sscw#define FROMBCD(x)      (int)((((unsigned int)(x)) >> 4) * 10 +\
141.3Sscw				(((unsigned int)(x)) & 0xf))
151.3Sscw#define TOBCD(x)        (int)((((unsigned int)(x)) / 10 * 16) +\
161.3Sscw				(((unsigned int)(x)) % 10))
171.2Schuck
181.2Schuck#define SECDAY          (24 * 60 * 60)
191.2Schuck#define SECYR           (SECDAY * 365)
201.2Schuck#define LEAPYEAR(y)     (((y) & 3) == 0)
211.2Schuck#define YEAR0		68
221.1Schuck
231.1Schuck/*
241.1Schuck * This code is defunct after 2068.
251.1Schuck * Will Unix still be here then??
261.1Schuck */
271.1Schuckconst short dayyr[12] =
281.8Stsutsui    {0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334};
291.1Schuck
301.4Sjdoleceku_long
311.5Sjunyoungchiptotime(int sec, int min, int hour, int day, int mon, int year)
321.1Schuck{
331.3Sscw	int days, yr;
341.1Schuck
351.1Schuck	sec = FROMBCD(sec);
361.1Schuck	min = FROMBCD(min);
371.1Schuck	hour = FROMBCD(hour);
381.1Schuck	day = FROMBCD(day);
391.1Schuck	mon = FROMBCD(mon);
401.1Schuck	year = FROMBCD(year) + YEAR0;
411.2Schuck	if (year < 70)
421.2Schuck		year = 70;
431.1Schuck
441.1Schuck	/* simple sanity checks */
451.1Schuck	if (year < 70 || mon < 1 || mon > 12 || day < 1 || day > 31)
461.1Schuck		return (0);
471.1Schuck	days = 0;
481.1Schuck	for (yr = 70; yr < year; yr++)
491.1Schuck		days += LEAPYEAR(yr) ? 366 : 365;
501.1Schuck	days += dayyr[mon - 1] + day - 1;
511.1Schuck	if (LEAPYEAR(yr) && mon > 2)
521.1Schuck		days++;
531.1Schuck	/* now have days since Jan 1, 1970; the rest is easy... */
541.8Stsutsui	return days * SECDAY + hour * 3600 + min * 60 + sec;
551.1Schuck}
561.1Schuck
571.9Stsutsuisatime_t
581.5Sjunyounggetsecs(void)
591.1Schuck{
601.2Schuck	struct mvmeprom_time m;
611.1Schuck
621.2Schuck	mvmeprom_rtc_rd(&m);
631.5Sjunyoung	return chiptotime(m.sec_BCD, m.min_BCD, m.hour_BCD, m.day_BCD,
641.8Stsutsui	    m.month_BCD, m.year_BCD);
651.1Schuck}
66