aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/include/linux/rtc/m48t59.h
blob: e8c7c21ceb1fe12b1f9e29a8868c59f8c1266874 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/*
 * include/linux/rtc/m48t59.h
 *
 * Definitions for the platform data of m48t59 RTC chip driver.
 *
 * Copyright (c) 2007 Wind River Systems, Inc.
 *
 * Mark Zhan <rongkai.zhan@windriver.com>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */

#ifndef _LINUX_RTC_M48T59_H_
#define _LINUX_RTC_M48T59_H_

/*
 * M48T59 Register Offset
 */
#define M48T59_YEAR		0x1fff
#define M48T59_MONTH		0x1ffe
#define M48T59_MDAY		0x1ffd	/* Day of Month */
#define M48T59_WDAY		0x1ffc	/* Day of Week */
#define M48T59_WDAY_CB			0x20	/* Century Bit */
#define M48T59_WDAY_CEB			0x10	/* Century Enable Bit */
#define M48T59_HOUR		0x1ffb
#define M48T59_MIN		0x1ffa
#define M48T59_SEC		0x1ff9
#define M48T59_CNTL		0x1ff8
#define M48T59_CNTL_READ		0x40
#define M48T59_CNTL_WRITE		0x80
#define M48T59_WATCHDOG		0x1ff7
#define M48T59_INTR		0x1ff6
#define M48T59_INTR_AFE			0x80	/* Alarm Interrupt Enable */
#define M48T59_INTR_ABE			0x20
#define M48T59_ALARM_DATE	0x1ff5
#define M48T59_ALARM_HOUR	0x1ff4
#define M48T59_ALARM_MIN	0x1ff3
#define M48T59_ALARM_SEC	0x1ff2
#define M48T59_UNUSED		0x1ff1
#define M48T59_FLAGS		0x1ff0
#define M48T59_FLAGS_WDT		0x80	/* watchdog timer expired */
#define M48T59_FLAGS_AF			0x40	/* alarm */
#define M48T59_FLAGS_BF			0x10	/* low battery */

#define M48T59_NVRAM_SIZE	0x1ff0

struct m48t59_plat_data {
	/* The method to access M48T59 registers,
	 * NOTE: The 'ofs' should be 0x00~0x1fff
	 */
	void (*write_byte)(struct device *dev, u32 ofs, u8 val);
	unsigned char (*read_byte)(struct device *dev, u32 ofs);
};

#endif /* _LINUX_RTC_M48T59_H_ */