177 lines
5.6 KiB
C
177 lines
5.6 KiB
C
|
/***************************************************************************
|
||
|
* __________ __ ___.
|
||
|
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
||
|
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
||
|
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
||
|
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
||
|
* \/ \/ \/ \/ \/
|
||
|
* $Id$
|
||
|
*
|
||
|
* Copyright (C) 2016 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 __MPR121_ZENXFI3_H__
|
||
|
#define __MPR121_ZENXFI3_H__
|
||
|
|
||
|
/** Driver for the Freescale MPR121 Capacitive Proximity Sensor */
|
||
|
#include "system.h"
|
||
|
|
||
|
#define ELECTRODE_COUNT 12
|
||
|
#define ELE_GPIO_FIRST 4
|
||
|
#define ELE_GPIO_LAST 11
|
||
|
|
||
|
/* gpio config (encoding: [0]=en,[1]=dir,[2]=ctl[1],[3]=ctl[0]) */
|
||
|
#define ELE_GPIO_DISABLE 0
|
||
|
#define ELE_GPIO_INPUT 1
|
||
|
#define ELE_GPIO_INPUT_PULLDOWN 9 /* input with pull-down */
|
||
|
#define ELE_GPIO_INPUT_PULLUP 13 /* input with pull-up */
|
||
|
#define ELE_GPIO_OUTPUT 3
|
||
|
#define ELE_GPIO_OUTPUT_OPEN 11 /* open drain low-side */
|
||
|
#define ELE_GPIO_OUTPUT_OPEN_LED 15 /* open drain high-side (led driver) */
|
||
|
|
||
|
/* internal use */
|
||
|
#define ELE_GPIO_EN(val) ((val) & 1)
|
||
|
#define ELE_GPIO_DIR(val) (((val) >> 1) & 1)
|
||
|
#define ELE_GPIO_CTL0(val) (((val) >> 3) & 1)
|
||
|
#define ELE_GPIO_CTL1(val) (((val) >> 1) & 1)
|
||
|
|
||
|
struct mpr121_electrode_config_t
|
||
|
{
|
||
|
uint8_t bv; /* baseline value */
|
||
|
uint8_t tth; /* touch threshold */
|
||
|
uint8_t rth; /* release threshold */
|
||
|
uint8_t cdc; /* charge current (optional if auto-conf) */
|
||
|
uint8_t cdt; /* charge time (optional if auto-conf) */
|
||
|
int gpio; /* gpio config */
|
||
|
};
|
||
|
|
||
|
struct mpr121_baseline_filter_config_t
|
||
|
{
|
||
|
uint8_t mhd; /* max half delta (except for touched) */
|
||
|
uint8_t nhd; /* noise half delta */
|
||
|
uint8_t ncl; /* noise count limit */
|
||
|
uint8_t fdl; /* filter delay count limit */
|
||
|
};
|
||
|
|
||
|
struct mpr121_baseline_filters_config_t
|
||
|
{
|
||
|
struct mpr121_baseline_filter_config_t rising;
|
||
|
struct mpr121_baseline_filter_config_t falling;
|
||
|
struct mpr121_baseline_filter_config_t touched;
|
||
|
};
|
||
|
|
||
|
struct mpr121_debounce_config_t
|
||
|
{
|
||
|
uint8_t dt; /* debounce count for touch */
|
||
|
uint8_t dr; /* debounce count for release */
|
||
|
};
|
||
|
|
||
|
/* first filter iterations */
|
||
|
#define FFI_6_SAMPLES 0
|
||
|
#define FFI_10_SAMPLES 1
|
||
|
#define FFI_18_SAMPLES 2
|
||
|
#define FFI_34_SAMPLES 3
|
||
|
/* charge discharge current */
|
||
|
#define CDC_DISABLE 0
|
||
|
#define CDC_uA(ua) (ua)
|
||
|
/* charge discharge time */
|
||
|
#define CDT_DISABLE 0
|
||
|
#define CDT_log_us(lus) (lus) /* actual value = 2^{us-2} µs */
|
||
|
/* second filter iterations */
|
||
|
#define SFI_4_SAMPLES 0
|
||
|
#define SFI_6_SAMPLES 1
|
||
|
#define SFI_10_SAMPLES 2
|
||
|
#define SFI_18_SAMPLES 3
|
||
|
/* Eletrode sample interval */
|
||
|
#define ESI_log_ms(lms) (lms) /* actual value = 2^{lms} ms */
|
||
|
|
||
|
struct mpr121_global_config_t
|
||
|
{
|
||
|
uint8_t ffi; /* first filter iterations */
|
||
|
uint8_t cdc; /* global charge discharge current */
|
||
|
uint8_t cdt; /* global charge discharge time */
|
||
|
uint8_t sfi; /* second first iterations */
|
||
|
uint8_t esi; /* electrode sample interval */
|
||
|
};
|
||
|
|
||
|
#define RETRY_NEVER 0
|
||
|
#define RETRY_2_TIMES 1
|
||
|
#define RETRY_4_TIMES 2
|
||
|
#define RETRY_8_TIMES 3
|
||
|
|
||
|
struct mpr121_auto_config_t
|
||
|
{
|
||
|
bool en; /* auto-conf enable */
|
||
|
bool ren; /* auto-reconf enable */
|
||
|
uint8_t retry; /* retry count */
|
||
|
bool scts; /* skip charge time search */
|
||
|
uint8_t usl; /* upper-side limit */
|
||
|
uint8_t lsl; /* lower-side limit */
|
||
|
uint8_t tl; /* target level */
|
||
|
bool acfie; /* auto-conf fail interrupt en */
|
||
|
bool arfie; /* auto-reconf fail interrupt en */
|
||
|
bool oorie; /* out of range interrupt en */
|
||
|
};
|
||
|
|
||
|
/* electrode mode */
|
||
|
#define ELE_DISABLE 0
|
||
|
#define ELE_EN0_x(x) ((x) + 1)
|
||
|
/* eleprox mode */
|
||
|
#define ELEPROX_DISABLE 0
|
||
|
#define ELEPROX_EN0_1 1
|
||
|
#define ELEPROX_EN0_3 2
|
||
|
#define ELEPROX_EN0_11 3
|
||
|
/* calibration lock */
|
||
|
#define CL_SLOW_TRACK 0
|
||
|
#define CL_DISABLE 1
|
||
|
#define CL_TRACK 2
|
||
|
#define CL_FAST_TRACK 3
|
||
|
|
||
|
struct mpr121_config_t
|
||
|
{
|
||
|
struct mpr121_electrode_config_t ele[ELECTRODE_COUNT];
|
||
|
struct mpr121_electrode_config_t eleprox;
|
||
|
struct
|
||
|
{
|
||
|
struct mpr121_baseline_filters_config_t ele;
|
||
|
struct mpr121_baseline_filters_config_t eleprox;
|
||
|
}filters;
|
||
|
struct mpr121_debounce_config_t debounce;
|
||
|
struct mpr121_global_config_t global;
|
||
|
struct mpr121_auto_config_t autoconf;
|
||
|
uint8_t ele_en; /* eletroce mode */
|
||
|
uint8_t eleprox_en; /* proximity mode */
|
||
|
uint8_t cal_lock; /* calibration lock */
|
||
|
};
|
||
|
|
||
|
/* gpio value */
|
||
|
#define ELE_GPIO_CLR 0
|
||
|
#define ELE_GPIO_SET 1
|
||
|
#define ELE_GPIO_TOG 2
|
||
|
/* pwm value */
|
||
|
#define ELE_PWM_DISABLE 0
|
||
|
#define ELE_PWM_DUTY(x) (x)
|
||
|
#define ELE_PWM_MIN_DUTY 1
|
||
|
#define ELE_PWM_MAX_DUTY 15
|
||
|
|
||
|
void mpr121_init(void);
|
||
|
void mpr121_set_config(struct mpr121_config_t *conf);
|
||
|
/* gpios are only implemented for electrode>=4, use ELE_GPIO_* for value */
|
||
|
void mpr121_set_gpio_output(int ele, int gpio_val);
|
||
|
/* pwm value is between 0 and 15, use ELE_PWM_DISABLE or ELE_PWM_DUTY */
|
||
|
void mpr121_set_gpio_pwm(int ele, int pwm);
|
||
|
/* get electrode status (bitmap)
|
||
|
* NOTE this function merely returns the last electrode status read from the
|
||
|
* device and does not actively ask the device for touch status. */
|
||
|
unsigned mpr121_get_touch_status(void);
|
||
|
|
||
|
#endif /* __MPR121_ZENXFI3_H__ */
|