2022-06-14 12:15:38 -05:00
|
|
|
/* SPDX-License-Identifier: BSD-2-Clause */
|
|
|
|
|
|
1998-07-28 23:03:40 +00:00
|
|
|
/*
|
2004-04-20 10:43:39 +00:00
|
|
|
* This file interfaces with the real-time clock found in
|
1998-07-28 23:03:40 +00:00
|
|
|
* a Mostek M48T08 or M48T18 or compatibles.
|
|
|
|
|
*
|
|
|
|
|
* Year 2K Notes:
|
|
|
|
|
*
|
|
|
|
|
* This chip only uses a two digit field to store the year. This
|
|
|
|
|
* code uses the RTEMS Epoch as a pivot year. This lets us map the
|
|
|
|
|
* two digit year field as follows:
|
|
|
|
|
*
|
|
|
|
|
* + two digit years 0-87 are mapped to 2000-2087.
|
|
|
|
|
* + two digit years 88-99 are mapped to 1988-1999.
|
|
|
|
|
*
|
|
|
|
|
* This is less than the time span supported by RTEMS.
|
|
|
|
|
*
|
1999-11-17 17:51:34 +00:00
|
|
|
* COPYRIGHT (c) 1989-1999.
|
1998-07-28 23:03:40 +00:00
|
|
|
* On-Line Applications Research Corporation (OAR).
|
|
|
|
|
*
|
2022-06-14 12:15:38 -05:00
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
|
* are met:
|
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
|
*
|
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
|
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
|
|
|
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
|
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
|
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
|
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
|
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
|
* POSSIBILITY OF SUCH DAMAGE.
|
1998-07-28 23:03:40 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#include <rtems.h>
|
|
|
|
|
#include <libchip/rtc.h>
|
|
|
|
|
#include <libchip/m48t08.h>
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Control register bits
|
|
|
|
|
*/
|
|
|
|
|
|
1998-07-29 00:03:07 +00:00
|
|
|
#define M48T08_CONTROL_WRITE 0x80
|
|
|
|
|
#define M48T08_CONTROL_READ 0x40
|
|
|
|
|
#define M48T08_CONTROL_SIGN 0x20
|
1998-07-28 23:03:40 +00:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* m48t08_initialize
|
|
|
|
|
*/
|
|
|
|
|
|
2008-09-22 11:45:25 +00:00
|
|
|
static void m48t08_initialize(
|
1998-07-28 23:03:40 +00:00
|
|
|
int minor
|
|
|
|
|
)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* m48t08_get_time
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#define From_BCD( _x ) ((((_x) >> 4) * 10) + ((_x) & 0x0F))
|
|
|
|
|
#define To_BCD( _x ) ((((_x) / 10) << 4) + ((_x) % 10))
|
|
|
|
|
|
2008-09-22 11:45:25 +00:00
|
|
|
static int m48t08_get_time(
|
1998-07-28 23:03:40 +00:00
|
|
|
int minor,
|
|
|
|
|
rtems_time_of_day *time
|
|
|
|
|
)
|
|
|
|
|
{
|
2004-03-23 Ralf Corsepius <ralf_corsepius@rtems.org>
* libchip/ide/ata.c, libchip/ide/ata_internal.h,
libchip/ide/ide_controller.c, libchip/ide/ide_ctrl_cfg.h,
libchip/ide/ide_ctrl_io.h, libchip/network/cs8900.c,
libchip/network/dec21140.c, libchip/network/elnk.c,
libchip/network/if_fxp.c, libchip/network/open_eth.c,
libchip/network/open_eth.h, libchip/network/sonic.c,
libchip/network/sonic.h, libchip/rtc/icm7170.c, libchip/rtc/icm7170.h,
libchip/rtc/icm7170_reg.c, libchip/rtc/icm7170_reg2.c,
libchip/rtc/icm7170_reg4.c, libchip/rtc/icm7170_reg8.c,
libchip/rtc/m48t08.c, libchip/rtc/m48t08.h, libchip/rtc/m48t08_reg.c,
libchip/rtc/m48t08_reg2.c, libchip/rtc/m48t08_reg4.c,
libchip/rtc/m48t08_reg8.c, libchip/rtc/rtc.h, libchip/serial/mc68681.c,
libchip/serial/mc68681.h, libchip/serial/mc68681_reg.c,
libchip/serial/mc68681_reg2.c, libchip/serial/mc68681_reg4.c,
libchip/serial/mc68681_reg8.c, libchip/serial/ns16550.c,
libchip/serial/ns16550_p.h, libchip/serial/serial.h,
libchip/serial/z85c30.c, libchip/serial/z85c30.h,
libchip/serial/z85c30_p.h, libchip/serial/z85c30_reg.c,
libchip/shmdr/addlq.c, libchip/shmdr/cnvpkt.c, libchip/shmdr/dump.c,
libchip/shmdr/fatal.c, libchip/shmdr/getlq.c, libchip/shmdr/init.c,
libchip/shmdr/initlq.c, libchip/shmdr/intr.c, libchip/shmdr/poll.c,
libchip/shmdr/send.c, libchip/shmdr/shm_driver.h: Convert to using c99
fixed-size types.
2004-03-23 09:59:52 +00:00
|
|
|
uint32_t m48t08;
|
1998-07-28 23:03:40 +00:00
|
|
|
getRegister_f getReg;
|
|
|
|
|
setRegister_f setReg;
|
2004-03-23 Ralf Corsepius <ralf_corsepius@rtems.org>
* libchip/ide/ata.c, libchip/ide/ata_internal.h,
libchip/ide/ide_controller.c, libchip/ide/ide_ctrl_cfg.h,
libchip/ide/ide_ctrl_io.h, libchip/network/cs8900.c,
libchip/network/dec21140.c, libchip/network/elnk.c,
libchip/network/if_fxp.c, libchip/network/open_eth.c,
libchip/network/open_eth.h, libchip/network/sonic.c,
libchip/network/sonic.h, libchip/rtc/icm7170.c, libchip/rtc/icm7170.h,
libchip/rtc/icm7170_reg.c, libchip/rtc/icm7170_reg2.c,
libchip/rtc/icm7170_reg4.c, libchip/rtc/icm7170_reg8.c,
libchip/rtc/m48t08.c, libchip/rtc/m48t08.h, libchip/rtc/m48t08_reg.c,
libchip/rtc/m48t08_reg2.c, libchip/rtc/m48t08_reg4.c,
libchip/rtc/m48t08_reg8.c, libchip/rtc/rtc.h, libchip/serial/mc68681.c,
libchip/serial/mc68681.h, libchip/serial/mc68681_reg.c,
libchip/serial/mc68681_reg2.c, libchip/serial/mc68681_reg4.c,
libchip/serial/mc68681_reg8.c, libchip/serial/ns16550.c,
libchip/serial/ns16550_p.h, libchip/serial/serial.h,
libchip/serial/z85c30.c, libchip/serial/z85c30.h,
libchip/serial/z85c30_p.h, libchip/serial/z85c30_reg.c,
libchip/shmdr/addlq.c, libchip/shmdr/cnvpkt.c, libchip/shmdr/dump.c,
libchip/shmdr/fatal.c, libchip/shmdr/getlq.c, libchip/shmdr/init.c,
libchip/shmdr/initlq.c, libchip/shmdr/intr.c, libchip/shmdr/poll.c,
libchip/shmdr/send.c, libchip/shmdr/shm_driver.h: Convert to using c99
fixed-size types.
2004-03-23 09:59:52 +00:00
|
|
|
uint8_t controlReg;
|
|
|
|
|
uint32_t value1;
|
|
|
|
|
uint32_t value2;
|
1998-07-28 23:03:40 +00:00
|
|
|
|
1998-07-29 00:03:07 +00:00
|
|
|
m48t08 = RTC_Table[ minor ].ulCtrlPort1;
|
|
|
|
|
getReg = RTC_Table[ minor ].getRegister;
|
|
|
|
|
setReg = RTC_Table[ minor ].setRegister;
|
1998-07-28 23:03:40 +00:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Put the RTC into read mode
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
controlReg = (*getReg)( m48t08, M48T08_CONTROL );
|
1998-07-29 00:03:07 +00:00
|
|
|
(*setReg)( m48t08, M48T08_CONTROL, controlReg | M48T08_CONTROL_READ );
|
2004-04-20 10:43:39 +00:00
|
|
|
|
1998-07-28 23:03:40 +00:00
|
|
|
value1 = (*getReg)( m48t08, M48T08_YEAR );
|
|
|
|
|
value2 = From_BCD( value1 );
|
|
|
|
|
if ( value2 < 88 )
|
|
|
|
|
time->year = 2000 + value2;
|
|
|
|
|
else
|
|
|
|
|
time->year = 1900 + value2;
|
|
|
|
|
|
|
|
|
|
value1 = (*getReg)( m48t08, M48T08_MONTH );
|
|
|
|
|
time->month = From_BCD( value1 );
|
|
|
|
|
|
|
|
|
|
value1 = (*getReg)( m48t08, M48T08_DATE );
|
|
|
|
|
time->day = From_BCD( value1 );
|
|
|
|
|
|
|
|
|
|
value1 = (*getReg)( m48t08, M48T08_HOUR );
|
|
|
|
|
time->hour = From_BCD( value1 );
|
|
|
|
|
|
|
|
|
|
value1 = (*getReg)( m48t08, M48T08_MINUTE );
|
|
|
|
|
time->minute = From_BCD( value1 );
|
|
|
|
|
|
|
|
|
|
value1 = (*getReg)( m48t08, M48T08_SECOND );
|
|
|
|
|
time->second = From_BCD( value1 );
|
2004-04-20 10:43:39 +00:00
|
|
|
|
1998-07-29 00:03:07 +00:00
|
|
|
time->ticks = 0;
|
|
|
|
|
|
1998-07-28 23:03:40 +00:00
|
|
|
/*
|
|
|
|
|
* Put the RTC back into normal mode.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
(*setReg)( m48t08, M48T08_CONTROL, controlReg );
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* m48t08_set_time
|
|
|
|
|
*/
|
|
|
|
|
|
2008-09-22 11:45:25 +00:00
|
|
|
static int m48t08_set_time(
|
1998-07-28 23:03:40 +00:00
|
|
|
int minor,
|
2008-09-22 11:45:25 +00:00
|
|
|
const rtems_time_of_day *time
|
1998-07-28 23:03:40 +00:00
|
|
|
)
|
|
|
|
|
{
|
2004-03-23 Ralf Corsepius <ralf_corsepius@rtems.org>
* libchip/ide/ata.c, libchip/ide/ata_internal.h,
libchip/ide/ide_controller.c, libchip/ide/ide_ctrl_cfg.h,
libchip/ide/ide_ctrl_io.h, libchip/network/cs8900.c,
libchip/network/dec21140.c, libchip/network/elnk.c,
libchip/network/if_fxp.c, libchip/network/open_eth.c,
libchip/network/open_eth.h, libchip/network/sonic.c,
libchip/network/sonic.h, libchip/rtc/icm7170.c, libchip/rtc/icm7170.h,
libchip/rtc/icm7170_reg.c, libchip/rtc/icm7170_reg2.c,
libchip/rtc/icm7170_reg4.c, libchip/rtc/icm7170_reg8.c,
libchip/rtc/m48t08.c, libchip/rtc/m48t08.h, libchip/rtc/m48t08_reg.c,
libchip/rtc/m48t08_reg2.c, libchip/rtc/m48t08_reg4.c,
libchip/rtc/m48t08_reg8.c, libchip/rtc/rtc.h, libchip/serial/mc68681.c,
libchip/serial/mc68681.h, libchip/serial/mc68681_reg.c,
libchip/serial/mc68681_reg2.c, libchip/serial/mc68681_reg4.c,
libchip/serial/mc68681_reg8.c, libchip/serial/ns16550.c,
libchip/serial/ns16550_p.h, libchip/serial/serial.h,
libchip/serial/z85c30.c, libchip/serial/z85c30.h,
libchip/serial/z85c30_p.h, libchip/serial/z85c30_reg.c,
libchip/shmdr/addlq.c, libchip/shmdr/cnvpkt.c, libchip/shmdr/dump.c,
libchip/shmdr/fatal.c, libchip/shmdr/getlq.c, libchip/shmdr/init.c,
libchip/shmdr/initlq.c, libchip/shmdr/intr.c, libchip/shmdr/poll.c,
libchip/shmdr/send.c, libchip/shmdr/shm_driver.h: Convert to using c99
fixed-size types.
2004-03-23 09:59:52 +00:00
|
|
|
uint32_t m48t08;
|
1998-07-28 23:03:40 +00:00
|
|
|
getRegister_f getReg;
|
|
|
|
|
setRegister_f setReg;
|
2004-03-23 Ralf Corsepius <ralf_corsepius@rtems.org>
* libchip/ide/ata.c, libchip/ide/ata_internal.h,
libchip/ide/ide_controller.c, libchip/ide/ide_ctrl_cfg.h,
libchip/ide/ide_ctrl_io.h, libchip/network/cs8900.c,
libchip/network/dec21140.c, libchip/network/elnk.c,
libchip/network/if_fxp.c, libchip/network/open_eth.c,
libchip/network/open_eth.h, libchip/network/sonic.c,
libchip/network/sonic.h, libchip/rtc/icm7170.c, libchip/rtc/icm7170.h,
libchip/rtc/icm7170_reg.c, libchip/rtc/icm7170_reg2.c,
libchip/rtc/icm7170_reg4.c, libchip/rtc/icm7170_reg8.c,
libchip/rtc/m48t08.c, libchip/rtc/m48t08.h, libchip/rtc/m48t08_reg.c,
libchip/rtc/m48t08_reg2.c, libchip/rtc/m48t08_reg4.c,
libchip/rtc/m48t08_reg8.c, libchip/rtc/rtc.h, libchip/serial/mc68681.c,
libchip/serial/mc68681.h, libchip/serial/mc68681_reg.c,
libchip/serial/mc68681_reg2.c, libchip/serial/mc68681_reg4.c,
libchip/serial/mc68681_reg8.c, libchip/serial/ns16550.c,
libchip/serial/ns16550_p.h, libchip/serial/serial.h,
libchip/serial/z85c30.c, libchip/serial/z85c30.h,
libchip/serial/z85c30_p.h, libchip/serial/z85c30_reg.c,
libchip/shmdr/addlq.c, libchip/shmdr/cnvpkt.c, libchip/shmdr/dump.c,
libchip/shmdr/fatal.c, libchip/shmdr/getlq.c, libchip/shmdr/init.c,
libchip/shmdr/initlq.c, libchip/shmdr/intr.c, libchip/shmdr/poll.c,
libchip/shmdr/send.c, libchip/shmdr/shm_driver.h: Convert to using c99
fixed-size types.
2004-03-23 09:59:52 +00:00
|
|
|
uint8_t controlReg;
|
1998-07-28 23:03:40 +00:00
|
|
|
|
1998-07-29 00:03:07 +00:00
|
|
|
m48t08 = RTC_Table[ minor ].ulCtrlPort1;
|
|
|
|
|
getReg = RTC_Table[ minor ].getRegister;
|
|
|
|
|
setReg = RTC_Table[ minor ].setRegister;
|
1998-07-28 23:03:40 +00:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Put the RTC into read mode
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
controlReg = (*getReg)( m48t08, M48T08_CONTROL );
|
1998-07-29 00:03:07 +00:00
|
|
|
(*setReg)( m48t08, M48T08_CONTROL, controlReg | M48T08_CONTROL_WRITE );
|
2004-04-20 10:43:39 +00:00
|
|
|
|
1998-07-28 23:03:40 +00:00
|
|
|
if ( time->year >= 2088 )
|
|
|
|
|
rtems_fatal_error_occurred( RTEMS_INVALID_NUMBER );
|
|
|
|
|
|
|
|
|
|
(*setReg)( m48t08, M48T08_YEAR, To_BCD(time->year % 100) );
|
|
|
|
|
(*setReg)( m48t08, M48T08_MONTH, To_BCD(time->month) );
|
|
|
|
|
(*setReg)( m48t08, M48T08_DATE, To_BCD(time->day) );
|
|
|
|
|
(*setReg)( m48t08, M48T08_HOUR, To_BCD(time->hour) );
|
|
|
|
|
(*setReg)( m48t08, M48T08_MINUTE, To_BCD(time->minute) );
|
|
|
|
|
(*setReg)( m48t08, M48T08_SECOND, To_BCD(time->second) );
|
2004-04-20 10:43:39 +00:00
|
|
|
|
1998-07-28 23:03:40 +00:00
|
|
|
/*
|
|
|
|
|
* Put the RTC back into normal mode.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
(*setReg)( m48t08, M48T08_CONTROL, controlReg );
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
1998-07-29 00:03:07 +00:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Driver function table
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
rtc_fns m48t08_fns = {
|
|
|
|
|
m48t08_initialize,
|
|
|
|
|
m48t08_get_time,
|
|
|
|
|
m48t08_set_time
|
|
|
|
|
};
|