rockbox/firmware/target/arm/imx233/button-lradc-imx233.h
Amaury Pouly 0324bf59a8 imx233: make button-lradc drive able to handle VDDIO derived values
In most devices, the button ladder is not actually derived from VDDIO but
from a constant voltage source, making it very easy to read it. However on
some devices like ther ZEN X-Fi Style, the ladder is wired to VDDIO we
can be changed so it's crucial that the button driver correctly scales the
values wrt VDDIO.

Change-Id: Ifc11abe2838fa7d16d0d60ecd96964a8dc5ea6d7
2014-02-10 23:14:25 +01:00

97 lines
4.1 KiB
C

/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
* $Id$
*
* Copyright (C) 2013 by Amaury Pouly
*
* 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 __button_lradc_imx233__
#define __button_lradc_imx233__
#include "button.h"
#include "button-target.h"
/** This driver implements button sensing with lradc. It does debouncing
* and can handle hold sensing too. It can be tweaked using the following defines
* and variables:
* - imx233_button_lradc_mapping: target-defined table of adc values and mapping
* - IMX233_BUTTON_LRADC_CHANNEL: lradc channel to use
* - IMX233_BUTTON_LRADC_HOLD_DET: define hold detection method (ignored if !HAS_BUTTON_HOLD)
* - IMX233_BUTTON_LRADC_MODE: define the button lradc mode
*
* The LRADC code supports two modes of operations: VDDIO relative or absolute.
* In the (default) absolute value mode, the LRADC channel is sampled and its value
* is compared to the one in the imx233_button_lradc_mapping table. This is
* appropriate when the resistor ladder is derived from a fixed voltage.
* In the VDDIO relative mode, the values in imx233_button_lradc_mapping are
* the values for a specific value of VDDIO which is given by
* IMX233_BUTTON_LRADC_VDDIO. In this mode, the code will also sample VDDIO
* and do the following comparison:
* lradc_value <=? imx233_button_lradc_mapping[i] * vddio_ref / vddio_value
* where vddio_ref is IMX233_BUTTON_LRADC_VDDIO.
*
* The available values of IMX233_BUTTON_LRADC_HOLD are:
* - BLH_ADC: detect hold using adc
* - BLH_EXT: target button driver implements imx233_button_lradc_hold() using
* any external method of its choice
* - BLH_GPIO: detect hold using a GPIO, needs to define additional defines:
* + BLH_GPIO_BANK: pin bank
* + BLH_GPIO_PIN: pin in bank
* + BLH_GPIO_INVERTED: define if inverted, default is active high
* + BLH_GPIO_PULLUP: define if pins needs pullup
*
* WARNING
* There must always be entry in imx233_button_lradc_mapping whose value is the steady
* value of the channel when no button is pressed, and which maps to no button (.btn = 0)
*/
/* hold detect method */
#define BLH_ADC 0
#define BLH_EXT 1
#define BLH_GPIO 2
/* special value for btn to indicate end of list */
#define IMX233_BUTTON_LRADC_END -1
/* special value for btn to handle HOLD */
#define IMX233_BUTTON_LRADC_HOLD -2
struct imx233_button_lradc_mapping_t
{
int adc_val;
int btn;
};
/* target-defined
* NOTE for proper operation, the table should contain entries for all states, including:
* - one with adc_val set to default value when no button is pressed
* - one with adc_val set to value when hold is selected (if hold is sensed using adc)
* - a dummy entry with btn set to IMX233_BUTTON_LRADC_END as the last entry
* The table must be sorted by increasing values of adc_val */
extern struct imx233_button_lradc_mapping_t imx233_button_lradc_mapping[];
void imx233_button_lradc_init(void);
/* others gives the bitmask of other buttons: the function will OR the result
* with them except if hold is detected in which case 0 is always returned */
int imx233_button_lradc_read(int others);
#ifdef HAS_BUTTON_HOLD
bool imx233_button_lradc_hold(void);
#endif
int imx233_button_lradc_read_raw(void); // return raw adc value
#ifdef IMX233_BUTTON_LRADC_VDDIO
int imx233_button_lradc_read_vddio(void);
#endif
#endif /* __button_lradc_imx233__ */