88c55d7290
- Enable end of charge monitoring once, it doesn't need to be disabled - Acknowledge the first (wrong) end of charge interrupt on charger enable (this had been broken in r25299) - Centralize reads to ENRD* registers and cache the results when needed - on PP it is not needed because reads are atomic, we only check for end of charge when the charging, and for charger presence when discharging as3525v2 (using as3543) specifics - I got the datasheet today from AMS, thanks to them for being so fast and not require me to sign tons of papers! - USB detection now works on as3525v2 using the as3543. Clip+ won't reboot to OF yet, it needs mkamsboot support first (usbstack disabled) - Charging should work, the CHARGER register is at a different place, it is an extended PMU register -> use ascodec_read/write_charger() to access it - real interrupts are not used yet for ENRD, we get thousands of interrupts per second, apparently only limited by the i2c clock. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@26116 a1c6a512-1295-4272-9138-f99709370657
103 lines
2.6 KiB
C
103 lines
2.6 KiB
C
/***************************************************************************
|
|
* __________ __ ___.
|
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
* \/ \/ \/ \/ \/
|
|
* $Id$
|
|
*
|
|
* Driver for AS3514 audio codec
|
|
*
|
|
* Copyright (c) 2007 Daniel Ankers
|
|
* Copyright (c) 2007 Christian Gmeiner
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
* KIND, either express or implied.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifndef _ASCODEC_TARGET_H
|
|
#define _ASCODEC_TARGET_H
|
|
|
|
#include "config.h"
|
|
|
|
#ifdef CPU_PP
|
|
/* TODO: This header is actually portalplayer specific, and should be
|
|
* moved into an appropriate subdir */
|
|
|
|
#include "as3514.h"
|
|
#include "i2c-pp.h"
|
|
|
|
static inline int ascodec_write(unsigned int reg, unsigned int value)
|
|
{
|
|
return pp_i2c_send(AS3514_I2C_ADDR, reg, value);
|
|
}
|
|
|
|
static inline int ascodec_read(unsigned int reg)
|
|
{
|
|
return i2c_readbyte(AS3514_I2C_ADDR, reg);
|
|
}
|
|
|
|
static inline int ascodec_readbytes(int addr, int len, unsigned char *data)
|
|
{
|
|
return i2c_readbytes(AS3514_I2C_ADDR, addr, len, data);
|
|
}
|
|
|
|
static inline void ascodec_lock(void)
|
|
{
|
|
i2c_lock();
|
|
}
|
|
|
|
static inline void ascodec_unlock(void)
|
|
{
|
|
i2c_unlock();
|
|
}
|
|
|
|
static inline bool ascodec_chg_status(void)
|
|
{
|
|
return ascodec_read(AS3514_IRQ_ENRD0) & CHG_STATUS;
|
|
}
|
|
|
|
static inline bool ascodec_endofch(void)
|
|
{
|
|
return ascodec_read(AS3514_IRQ_ENRD0) & CHG_ENDOFCH;
|
|
}
|
|
|
|
static inline void ascodec_monitor_endofch(void)
|
|
{
|
|
ascodec_write(AS3514_IRQ_ENRD0, IRQ_ENDOFCH);
|
|
}
|
|
|
|
static inline void ascodec_wait_adc_finished(void)
|
|
{
|
|
/*
|
|
* FIXME: not implemented
|
|
*
|
|
* If irqs are not available on the target platform,
|
|
* this should be most likely implemented by polling
|
|
* AS3514_IRQ_ENRD2 in the same way powermgmt-ascodec.c
|
|
* is polling IRQ_ENDOFCH.
|
|
*/
|
|
}
|
|
|
|
static inline void ascodec_write_charger(int value)
|
|
{
|
|
ascodec_write(AS3514_CHARGER, value);
|
|
}
|
|
|
|
static inline int ascodec_read_charger(void)
|
|
{
|
|
return ascodec_read(AS3514_CHARGER);
|
|
}
|
|
|
|
extern void ascodec_suppressor_on(bool on);
|
|
|
|
#endif /* CPU_PP */
|
|
|
|
#endif /* !_ASCODEC_TARGET_H */
|