summaryrefslogtreecommitdiffstats
path: root/firmware/target/arm/imx233/button-lradc-imx233.h
blob: d96823fcdce4e627f27407efc17bc5e2dd6c5167 (plain)
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/***************************************************************************
 *             __________               __   ___.
 *   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__ */