/* $NetBSD: r2025reg.h,v 1.1 2006/03/06 19:55:08 shige Exp $ */
/*-
* Copyright (c) 2006 Shigeyuki Fukushima.
* All rights reserved.
*
* Written by Shigeyuki Fukushima.
*
* 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.
* 3. The name of the author may not be used to endorse or promote
* products derived from this software without specific prior
* written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.
*/
#ifndef _DEV_I2C_R2025REG_H_
#define _DEV_I2C_R2025REG_H_
/*
* R2025S/D Real-Time Clock
*/
/* I2C Slave Address */
#define R2025_ADDR 0x32
/* Register size */
#define R2025_REG_SIZE 16
#define R2025_CLK_SIZE 7 /* 7bytes: 0x0-0x6 */
/* Registers */
#define R2025_REG_SEC 0x0
#define R2025_REG_MIN 0x1
#define R2025_REG_HOUR 0x2
#define R2025_REG_WDAY 0x3
#define R2025_REG_DAY 0x4
#define R2025_REG_MON 0x5
#define R2025_REG_YEAR 0x6
#define R2025_REG_CORRECTCLOCK 0x7
#define R2025_REG_ALARMW_MIN 0x8
#define R2025_REG_ALARMW_HOUR 0x9
#define R2025_REG_ALARMW_WDAY 0xa
#define R2025_REG_ALARMD_MIN 0xb
#define R2025_REG_ALARMD_HOUR 0xc
#define R2025_REG_RESERVED 0xd
#define R2025_REG_CTRL1 0xe
#define R2025_REG_CTRL2 0xf
/* Register mask */
#define R2025_REG_SEC_MASK 0x7f
#define R2025_REG_MIN_MASK 0x7f
#define R2025_REG_HOUR_MASK 0x3f
#define R2025_REG_WDAY_MASK 0x07
#define R2025_REG_DAY_MASK 0x3f
#define R2025_REG_MON_MASK 0x1f
#define R2025_REG_YEAR_MASK 0xff
#define R2025_REG_CORRECTCLOCK_MASK 0x7f
#define R2025_REG_ALARMW_MIN_MASK 0x7f
#define R2025_REG_ALARMW_HOUR_MASK 0x3f
#define R2025_REG_ALARMW_WDAY_MASK 0x7f
#define R2025_REG_ALARMD_MIN_MASK 0x7f
#define R2025_REG_ALARMD_HOUR_MASK 0x3f
#define R2025_REG_CTRL1_MASK 0xff
#define R2025_REG_CTRL2_MASK 0xff
/* Register flag: R2025_MON */
#define R2025_REG_MON_Y1920 (1u << 7)
/* Register flag: R2025_CTRL1 */
#define R2025_REG_CTRL1_WALE (1u << 7)
#define R2025_REG_CTRL1_DALE (1u << 6)
#define R2025_REG_CTRL1_H1224 (1u << 5)
#define R2025_REG_CTRL1_CLEN2 (1u << 4)
#define R2025_REG_CTRL1_TEST (1u << 3)
#define R2025_REG_CTRL1_CT2 (1u << 2)
#define R2025_REG_CTRL1_CT1 (1u << 1)
#define R2025_REG_CTRL1_CT0 (1u << 0)
/* Register flag: R2025_CTRL2 */
#define R2025_REG_CTRL2_VDSL (1u << 7)
#define R2025_REG_CTRL2_VDET (1u << 6)
#define R2025_REG_CTRL2_XST (1u << 5)
#define R2025_REG_CTRL2_PON (1u << 4)
#define R2025_REG_CTRL2_CLEN1 (1u << 3)
#define R2025_REG_CTRL2_CTFG (1u << 2)
#define R2025_REG_CTRL2_WAFG (1u << 1)
#define R2025_REG_CTRL2_DAFG (1u << 0)
#endif /* _DEV_I2C_R2025REG_H_ */