rockbox/firmware/drivers/pcf50605.c

115 lines
3.2 KiB
C
Raw Normal View History

/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
* $Id$
*
* Driver for pcf50605 PMU and RTC
*
* 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)
*
* 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 "system.h"
#include "config.h"
#if CONFIG_I2C == I2C_PP5020 || CONFIG_I2C == I2C_PP5002
#include "i2c-pp.h"
#endif
#include "rtc.h"
#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
#define D1REGC1 0x24
#define VOUT_3000mV 0xf5
#define VOUT_3300mV 0xf8
#define D2REGC1 0x25
#define D3REGC1 0x26
int pcf50605_read(int address)
{
return i2c_readbyte(0x8,address);
}
int pcf50605_read_multiple(int address, unsigned char* buf, int count)
{
int read = i2c_readbytes(0x08, address, count, buf);
return read - count;
}
int pcf50605_write(int address, unsigned char val)
{
pp_i2c_send(0x8, address, val);
return 0;
}
int pcf50605_write_multiple(int address, const unsigned char* buf, int count)
{
int i;
for (i = 0; i < count; i++)
pp_i2c_send(0x8, address + i, buf[i]);
return 0;
}
/* 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)
{
const char mask = pcf50605_read(OOCC1) | GOSTDBY | CHGWAK | EXTONWAK;
pcf50605_write(OOCC1, mask);
}
void pcf50605_init(void)
{
/* The following values were taken from the ipodlinux kernel source */
pcf50605_write(D1REGC1, VOUT_3000mV); /* Unknown */
pcf50605_write(D2REGC1, VOUT_3300mV); /* Dock Connector pin 17 */
pcf50605_write(D3REGC1, VOUT_3000mV); /* Unknown */
}