Home | History | Annotate | Line # | Download | only in libsa
chiptotime.c revision 1.1
      1  1.1  jdolecek /*	$NetBSD: chiptotime.c,v 1.1 2000/07/24 18:39:44 jdolecek Exp $ */
      2  1.1  jdolecek 
      3  1.1  jdolecek #include <sys/types.h>
      4  1.1  jdolecek 
      5  1.1  jdolecek #include <machine/prom.h>
      6  1.1  jdolecek 
      7  1.1  jdolecek #include "stand.h"
      8  1.1  jdolecek #include "libsa.h"
      9  1.1  jdolecek 
     10  1.1  jdolecek /*
     11  1.1  jdolecek  * BCD to decimal and decimal to BCD.
     12  1.1  jdolecek  */
     13  1.1  jdolecek #define FROMBCD(x)      (int)((((unsigned int)(x)) >> 4) * 10 +\
     14  1.1  jdolecek 				(((unsigned int)(x)) & 0xf))
     15  1.1  jdolecek #define TOBCD(x)        (int)((((unsigned int)(x)) / 10 * 16) +\
     16  1.1  jdolecek 				(((unsigned int)(x)) % 10))
     17  1.1  jdolecek 
     18  1.1  jdolecek #define SECDAY          (24 * 60 * 60)
     19  1.1  jdolecek #define SECYR           (SECDAY * 365)
     20  1.1  jdolecek #define LEAPYEAR(y)     (((y) & 3) == 0)
     21  1.1  jdolecek #define YEAR0		68
     22  1.1  jdolecek 
     23  1.1  jdolecek /*
     24  1.1  jdolecek  * This code is defunct after 2068.
     25  1.1  jdolecek  * Will Unix still be here then??
     26  1.1  jdolecek  */
     27  1.1  jdolecek const short dayyr[12] =
     28  1.1  jdolecek {0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334};
     29  1.1  jdolecek 
     30  1.1  jdolecek u_long
     31  1.1  jdolecek chiptotime(sec, min, hour, day, mon, year)
     32  1.1  jdolecek 	int sec, min, hour, day, mon, year;
     33  1.1  jdolecek {
     34  1.1  jdolecek 	int days, yr;
     35  1.1  jdolecek 
     36  1.1  jdolecek 	sec = FROMBCD(sec);
     37  1.1  jdolecek 	min = FROMBCD(min);
     38  1.1  jdolecek 	hour = FROMBCD(hour);
     39  1.1  jdolecek 	day = FROMBCD(day);
     40  1.1  jdolecek 	mon = FROMBCD(mon);
     41  1.1  jdolecek 	year = FROMBCD(year) + YEAR0;
     42  1.1  jdolecek 	if (year < 70)
     43  1.1  jdolecek 		year = 70;
     44  1.1  jdolecek 
     45  1.1  jdolecek 	/* simple sanity checks */
     46  1.1  jdolecek 	if (year < 70 || mon < 1 || mon > 12 || day < 1 || day > 31)
     47  1.1  jdolecek 		return (0);
     48  1.1  jdolecek 	days = 0;
     49  1.1  jdolecek 	for (yr = 70; yr < year; yr++)
     50  1.1  jdolecek 		days += LEAPYEAR(yr) ? 366 : 365;
     51  1.1  jdolecek 	days += dayyr[mon - 1] + day - 1;
     52  1.1  jdolecek 	if (LEAPYEAR(yr) && mon > 2)
     53  1.1  jdolecek 		days++;
     54  1.1  jdolecek 	/* now have days since Jan 1, 1970; the rest is easy... */
     55  1.1  jdolecek 	return (days * SECDAY + hour * 3600 + min * 60 + sec);
     56  1.1  jdolecek }
     57