2005-12-11 10:52:17 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* __________ __ ___.
|
|
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
|
|
* \/ \/ \/ \/ \/
|
|
|
|
* $Id$
|
|
|
|
*
|
2005-12-19 14:30:52 +00:00
|
|
|
* Driver for pcf50605 PMU and RTC
|
2005-12-11 10:52:17 +00:00
|
|
|
*
|
2005-12-19 14:30:52 +00:00
|
|
|
* Based on code from the ipodlinux project - http://ipodlinux.org/
|
|
|
|
* Adapted for Rockbox in December 2005
|
|
|
|
*
|
|
|
|
* Original file: linux/arch/armnommu/mach-ipod/pcf50605.c
|
|
|
|
*
|
|
|
|
* Copyright (c) 2003-2005 Bernard Leach (leachbj@bouncycastle.org)
|
2005-12-11 10:52:17 +00:00
|
|
|
*
|
|
|
|
* All files in this archive are subject to the GNU General Public License.
|
|
|
|
* See the file COPYING in the source tree root for full license agreement.
|
|
|
|
*
|
|
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
* KIND, either express or implied.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
|
|
|
#include "config.h"
|
2006-02-05 17:16:34 +00:00
|
|
|
#if CONFIG_I2C == I2C_PP5020
|
2005-12-11 10:52:17 +00:00
|
|
|
#include "i2c-pp5020.h"
|
2006-02-05 17:16:34 +00:00
|
|
|
#elif CONFIG_I2C == I2C_PP5002
|
|
|
|
#include "i2c-pp5002.h"
|
|
|
|
#endif
|
2005-12-11 10:52:17 +00:00
|
|
|
#include "rtc.h"
|
|
|
|
|
2005-12-21 23:32:19 +00:00
|
|
|
#define OOCS 0x01
|
|
|
|
#define INT1 0x02
|
|
|
|
#define INT2 0x03
|
|
|
|
#define INT3 0x04
|
|
|
|
#define INT1M 0x05
|
|
|
|
#define INT2M 0x06
|
|
|
|
#define INT3M 0x07
|
|
|
|
#define OOCC1 0x08
|
|
|
|
#define GOSTDBY 0x1
|
|
|
|
#define TOTRST (0x1 << 1)
|
|
|
|
#define CLK32ON (0x1 << 2)
|
|
|
|
#define WDTRST (0x1 << 3)
|
|
|
|
#define RTCWAK (0x1 << 4)
|
|
|
|
#define CHGWAK (0x1 << 5)
|
|
|
|
#define EXTONWAK (0x01 << 6)
|
|
|
|
#define OOCC2 0x09
|
|
|
|
#define RTCSC 0x0a
|
|
|
|
#define RTCMN 0x0b
|
|
|
|
#define RTCHR 0x0c
|
|
|
|
#define RTCWD 0x0d
|
|
|
|
#define RTCDT 0x0e
|
|
|
|
#define RTCMT 0x0f
|
|
|
|
#define RTCYR 0x10
|
|
|
|
#define RTCSCA 0x11
|
|
|
|
#define RTCMNA 0x12
|
|
|
|
#define RTCHRA 0x13
|
|
|
|
#define RTCWDA 0x14
|
|
|
|
#define RTCDTA 0x15
|
|
|
|
#define RTCMTA 0x16
|
|
|
|
#define RTCYRA 0x17
|
|
|
|
#define PSSC 0x18
|
|
|
|
#define PWROKM 0x19
|
|
|
|
#define PWROKS 0x1a
|
|
|
|
|
2005-12-11 10:52:17 +00:00
|
|
|
int pcf50605_read(int address)
|
|
|
|
{
|
|
|
|
return i2c_readbyte(0x8,address);
|
|
|
|
}
|
|
|
|
|
|
|
|
int pcf50605_read_multiple(int address, unsigned char* buf, int count)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i=0;i<count;i++)
|
|
|
|
{
|
|
|
|
buf[i]=pcf50605_read(address);
|
|
|
|
address++;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int pcf50605_write(int address, unsigned char val)
|
|
|
|
{
|
2005-12-21 23:32:19 +00:00
|
|
|
ipod_i2c_send(0x8, address, val);
|
2005-12-11 10:52:17 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int pcf50605_write_multiple(int address, const unsigned char* buf, int count)
|
|
|
|
{
|
|
|
|
/* TODO */
|
|
|
|
(void)address;
|
|
|
|
(void)buf;
|
|
|
|
(void)count;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int pcf50605_a2d_read(int adc_input)
|
|
|
|
{
|
|
|
|
int hi, lo;
|
|
|
|
|
|
|
|
/* Enable ACD module */
|
|
|
|
ipod_i2c_send(0x8, 0x33, 0x80); /* ACDC1, ACDAPE = 1 */
|
|
|
|
|
|
|
|
/* select ADCIN1 - subtractor, and start sampling process */
|
|
|
|
ipod_i2c_send(0x8, 0x2f, (adc_input<<1) | 0x1); /* ADCC2, ADCMUX = adc_input, ADCSTART = 1 */
|
|
|
|
|
|
|
|
/* ADCC2, wait for ADCSTART = 0 (wait for sampling to start) */
|
|
|
|
while ((i2c_readbyte(0x8, 0x2f) & 1)) /* do nothing */;
|
|
|
|
|
|
|
|
/* ADCS2, wait ADCRDY = 0 (wait for sampling to end) */
|
|
|
|
while (!(i2c_readbyte(0x8, 0x31) & 0x80)) /* do nothing */;
|
|
|
|
|
|
|
|
hi = i2c_readbyte(0x8, 0x30); /* ADCS1 */
|
|
|
|
lo = (i2c_readbyte(0x8, 0x31) & 0x3); /* ADCS2 */
|
|
|
|
|
|
|
|
return (hi << 2) | lo;
|
|
|
|
}
|
|
|
|
|
2005-12-21 23:32:19 +00:00
|
|
|
/* The following command puts the iPod into a deep sleep. Warning
|
|
|
|
from the good people of ipodlinux - never issue this command
|
|
|
|
without setting CHGWAK or EXTONWAK if you ever want to be able to
|
|
|
|
power on your iPod again. */
|
|
|
|
void pcf50605_standby_mode(void)
|
|
|
|
{
|
|
|
|
pcf50605_write(OOCC1, GOSTDBY | CHGWAK | EXTONWAK);
|
|
|
|
}
|
|
|
|
|
2005-12-11 10:52:17 +00:00
|
|
|
int pcf50605_battery_read(void)
|
|
|
|
{
|
|
|
|
return pcf50605_a2d_read(0x3); /* ADCIN1, subtractor */
|
|
|
|
}
|
|
|
|
|
|
|
|
void rtc_init(void)
|
|
|
|
{
|
|
|
|
/* Nothing to do. */
|
|
|
|
}
|
|
|
|
|
|
|
|
int rtc_read_datetime(unsigned char* buf)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
rc = pcf50605_read_multiple(0x0a, buf, 7);
|
|
|
|
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int rtc_write_datetime(unsigned char* buf)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i=0;i<7;i++) {
|
|
|
|
ipod_i2c_send(0x8, 0x0a+i, buf[i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|