2014-08-27 18:47:31 +02:00
|
|
|
/*
|
|
|
|
* Copyright 2008, Freie Universitaet Berlin (FUB). All rights reserved.
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2010-12-13 01:29:46 +01:00
|
|
|
#ifndef LPC2387_RTC_H
|
|
|
|
#define LPC2387_RTC_H
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
2014-07-31 20:46:28 +02:00
|
|
|
* @defgroup lpc2387_rtc LPC2387 Real-Time-Clock
|
|
|
|
* @ingroup lpc2387
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2014-07-31 20:46:28 +02:00
|
|
|
* \section lpc2387_rtc_newlib Standard library support
|
2010-09-22 15:10:42 +02:00
|
|
|
* Currently reading and setting time and date through standard C functions is implemented.
|
|
|
|
* Standard C timers are not available.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
2014-07-31 20:46:28 +02:00
|
|
|
* @brief LPC2387 Real-Time-Clock
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
2013-03-08 11:30:23 +01:00
|
|
|
* @author Freie Universität Berlin, Computer Systems & Telematics
|
2010-09-22 15:10:42 +02:00
|
|
|
* @version $Revision: 1998 $
|
|
|
|
*
|
2014-07-31 20:46:28 +02:00
|
|
|
* @note $Id: lpc2387-rtc.h 1998 2010-03-16 13:05:41Z baar $
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <time.h>
|
|
|
|
#include <sys/time.h>
|
2013-12-16 17:54:58 +01:00
|
|
|
#include "rtc.h"
|
2010-09-22 15:10:42 +02:00
|
|
|
#include "lpc2387.h"
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------- */
|
|
|
|
/**
|
|
|
|
* @name LPC2387 RTC Compile-Time Configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:46:28 +02:00
|
|
|
* @brief Mask for RTC alarms
|
|
|
|
* @see ::rtc_set_alarm, ::rtc_get_alarm
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
enum rtc_alarm_mask {
|
2014-07-31 20:46:28 +02:00
|
|
|
RTC_AMR_DISABLED = 0, ///< Alarm disables
|
|
|
|
RTC_AMR_SEC = AMRSEC, ///< Alarm mask for Seconds
|
|
|
|
RTC_AMR_MIN = AMRMIN, ///< Alarm mask for Minutes
|
|
|
|
RTC_AMR_HOUR = AMRHOUR, ///< Alarm mask for Hours
|
|
|
|
RTC_AMR_DOM = AMRDOM, ///< Alarm mask for Day of Month
|
|
|
|
RTC_AMR_DOW = AMRDOW, ///< Alarm mask for Day of Week
|
|
|
|
RTC_AMR_DOY = AMRDOY, ///< Alarm mask for Day of Year
|
|
|
|
RTC_AMR_MON = AMRMON, ///< Alarm mask for Month
|
|
|
|
RTC_AMR_YEAR = AMRYEAR, ///< Alarm mask for Year
|
2010-09-22 15:10:42 +02:00
|
|
|
};
|
|
|
|
|
2010-11-04 18:16:39 +01:00
|
|
|
void rtc_reset(void);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
2014-07-31 20:46:28 +02:00
|
|
|
* @brief Returns the time of compilation in seconds
|
2010-09-22 15:10:42 +02:00
|
|
|
* @internal
|
|
|
|
*/
|
|
|
|
time_t rtc_get_compile_time(void) __attribute__((noinline));
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:46:28 +02:00
|
|
|
* @brief Returns the current clock time
|
|
|
|
* @param[out] time optional return value
|
|
|
|
* @return clock time in seconds
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
2013-06-21 03:52:57 +02:00
|
|
|
time_t rtc_time(struct timeval *time);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
2014-07-31 20:46:28 +02:00
|
|
|
* @brief Sets the current clock time
|
|
|
|
* @param[in] time new time in seconds
|
|
|
|
* @note Any set alarm is shifted
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
|
|
|
void rtc_set(time_t time);
|
|
|
|
|
|
|
|
/**
|
2014-07-31 20:46:28 +02:00
|
|
|
* @brief Sets the alarm
|
2010-09-22 15:10:42 +02:00
|
|
|
* @internal
|
2014-07-31 20:46:28 +02:00
|
|
|
* @param[in] localt Alarm time
|
|
|
|
* @param[in] mask Sets the registers to poll for the alarm
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* To disable the alarm set mask to RTC_AMR_DISABLED.
|
|
|
|
*
|
|
|
|
* @see ::rtc_alarm_mask
|
|
|
|
*/
|
2013-06-21 03:52:57 +02:00
|
|
|
void rtc_set_alarm(struct tm *localt, enum rtc_alarm_mask mask);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
2014-07-31 20:46:28 +02:00
|
|
|
* @brief Gets the current alarm setting
|
2010-09-22 15:10:42 +02:00
|
|
|
* @internal
|
2014-07-31 20:46:28 +02:00
|
|
|
* @param[out] localt Pointer to structure to receive alarm time
|
|
|
|
* @return Alarm mask
|
2010-09-22 15:10:42 +02:00
|
|
|
*
|
|
|
|
* @see rtc_set_alarm
|
|
|
|
* @see ::rtc_alarm_mask
|
|
|
|
*/
|
2013-06-21 03:52:57 +02:00
|
|
|
enum rtc_alarm_mask _rtc_get_alarm(struct tm *localt);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/** @} */
|
|
|
|
#endif /* end __RTC_H */
|