Source
dev_emerg(&imxdi->pdev->dev, "Please cycle the %s power supply in order to get the DryIce/RTC unit working again\n",
/*
* Copyright 2008-2009 Freescale Semiconductor, Inc. All Rights Reserved.
* Copyright 2010 Orex Computed Radiography
*/
/*
* The code contained herein is licensed under the GNU General Public
* License. You may obtain a copy of the GNU General Public License
* Version 2 or later at the following locations:
*
* http://www.opensource.org/licenses/gpl-license.html
* http://www.gnu.org/copyleft/gpl.html
*/
/* based on rtc-mc13892.c */
/*
* This driver uses the 47-bit 32 kHz counter in the Freescale DryIce block
* to implement a Linux RTC. Times and alarms are truncated to seconds.
* Since the RTC framework performs API locking via rtc->ops_lock the
* only simultaneous accesses we need to deal with is updating DryIce
* registers while servicing an alarm.
*
* Note that reading the DSR (DryIce Status Register) automatically clears
* the WCF (Write Complete Flag). All DryIce writes are synchronized to the
* LP (Low Power) domain and set the WCF upon completion. Writes to the
* DIER (DryIce Interrupt Enable Register) are the only exception. These
* occur at normal bus speeds and do not set WCF. Periodic interrupts are
* not supported by the hardware.
*/
/* DryIce Register Definitions */
/* Time Counter MSB Reg */
/* Time Counter LSB Reg */
/* Clock Alarm MSB Reg */
/* Clock Alarm LSB Reg */
/* doomsday - 1 sec */
/* Control Reg */
/* Tamper-detect configuration hard lock */
/* Tamper-detect configuration soft lock */
/* Key-select soft lock */
/* Monotonic-counter hard lock */
/* Monotonic-counter soft lock */
/* Timer-counter hard lock */
/* Timer-counter soft lock */
/* Failure state hard lock */
/* Time Counter Enable */
/* Monotonic Counter Enable */