/* ChibiOS/GFX - Copyright (C) 2012 Joel Bodenmann aka Tectu This file is part of ChibiOS/GFX. ChibiOS/GFX 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 3 of the License, or (at your option) any later version. ChibiOS/GFX is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ /** * @file drivers/ginput/touch/STMPE811/stmpe811.h * @brief GINPUT Input Driver support header for the STMPE811 touch controller. * * @addtogroup GINPUT * @{ */ #ifndef _STMPE811_H #define _STMPE811_H /* STMPE811 registers */ // Identification registers #define STMPE811_REG_CHP_ID 0x00 // 16-bit #define STMPE811_REG_ID_VER 0x02 // System registers #define STMPE811_REG_SYS_CTRL1 0x03 #define STMPE811_REG_SYS_CTRL2 0x04 #define STMPE811_REG_SPI_CFG 0x08 // Interrupt control registers #define STMPE811_REG_INT_CTRL 0x09 #define STMPE811_REG_INT_EN 0x0A #define STMPE811_REG_INT_STA 0x0B #define STMPE811_REG_GPIO_INT_EN 0x0C #define STMPE811_REG_GPIO_INT_STA 0x0D #define STMPE811_REG_ADC_INT_EN 0x0E #define STMPE811_REG_ADC_INT_STA 0x0F // GPIO registers #define STMPE811_REG_GPIO_SET_PIN 0x10 #define STMPE811_REG_GPIO_CLR_PIN 0x11 #define STMPE811_REG_GPIO_MP_STA 0x12 #define STMPE811_REG_GPIO_DIR 0x13 #define STMPE811_REG_GPIO_ED 0x14 #define STMPE811_REG_GPIO_RE 0x15 #define STMPE811_REG_GPIO_FE 0x16 #define STMPE811_REG_GPIO_AF 0x17 // ADC registers #define STMPE811_REG_ADC_CTRL1 0x20 #define STMPE811_REG_ADC_CTRL2 0x21 #define STMPE811_REG_ADC_CAPT 0x22 #define STMPE811_REG_ADC_DATA_CH0 0x30 // 16-bit #define STMPE811_REG_ADC_DATA_CH1 0x32 // 16-bit #define STMPE811_REG_ADC_DATA_CH2 0x34 // 16-bit #define STMPE811_REG_ADC_DATA_CH3 0x36 // 16-bit #define STMPE811_REG_ADC_DATA_CH4 0x38 // 16-bit #define STMPE811_REG_ADC_DATA_CH5 0x3A // 16-bit #define STMPE811_REG_ADC_DATA_CH6 0x3B // 16-bit #define STMPE811_REG_ADC_DATA_CH7 0x3C // 16-bit // Touchscreen registers #define STMPE811_REG_TSC_CTRL 0x40 #define STMPE811_REG_TSC_CFG 0x41 #define STMPE811_REG_WDW_TR_X 0x42 // 16-bit #define STMPE811_REG_WDW_TR_Y 0x44 // 16-bit #define STMPE811_REG_WDW_BL_X 0x46 // 16-bit #define STMPE811_REG_WDW_BL_Y 0x48 // 16-bit #define STMPE811_REG_FIFO_TH 0x4A #define STMPE811_REG_FIFO_STA 0x4B #define STMPE811_REG_FIFO_SIZE 0x4C #define STMPE811_REG_TSC_DATA_X 0x4D // 16-bit #define STMPE811_REG_TSC_DATA_Y 0x4F // 16-bit #define STMPE811_REG_TSC_DATA_Z 0x51 #define STMPE811_REG_TSC_DATA_XYZ 0x52 #define STMPE811_REG_TSC_FRACT_XYZ 0x56 // 32-bit #define STMPE811_REG_TSC_DATA 0x57 #define STMPE811_REG_TSC_I_DRIVE 0x58 #define STMPE811_REG_TSC_SHIELD 0x59 // Temperature sensor registers #define STMPE811_REG_TEMP_CTRL 0x60 #define STMPE811_REG_TEMP_DATA 0x61 #define STMPE811_REG_TEMP_TH 0x62 #endif /* _STMPE811_H */ /** @} */