diff --git a/drivers/ginput/touch/STMPE811/ginput_lld_mouse.c b/drivers/ginput/touch/STMPE811/ginput_lld_mouse.c index b83f0cf4..bacb1f1f 100644 --- a/drivers/ginput/touch/STMPE811/ginput_lld_mouse.c +++ b/drivers/ginput/touch/STMPE811/ginput_lld_mouse.c @@ -31,12 +31,19 @@ #include "hal.h" #include "gfx.h" +#include "stmpe811.h" + #if (GFX_USE_GINPUT && GINPUT_NEED_MOUSE) /*|| defined(__DOXYGEN__)*/ #include "ginput/lld/mouse.h" -//#include "ginput_lld_mouse_board_example.h" -#include "ginput_lld_mouse_board_embest_lcd.h" +#if defined(GINPUT_MOUSE_USE_CUSTOM_BOARD) && GINPUT_MOUSE_USE_CUSTOM_BOARD + #include "ginput_lld_mouse_board.h" +#elif defined(BOARD_EMBEST_DMSTF4BB) + #include "ginput_lld_mouse_board_embest_dmstf4bb.h" +#else + #include "ginput_lld_mouse_board_example.h" +#endif static uint16_t sampleBuf[7]; static coord_t lastx, lasty; @@ -135,4 +142,3 @@ void ginput_lld_mouse_get_reading(MouseReading *pt) { #endif /* GFX_USE_GINPUT && GINPUT_NEED_MOUSE */ /** @} */ - diff --git a/drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_embest_lcd.h b/drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_embest_dmstf4bb.h similarity index 93% rename from drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_embest_lcd.h rename to drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_embest_dmstf4bb.h index 8dd28a90..0ffbec2a 100644 --- a/drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_embest_lcd.h +++ b/drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_embest_dmstf4bb.h @@ -19,8 +19,8 @@ */ /** - * @file drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_example.h - * @brief GINPUT Touch low level driver source for the STMPE811 on the example board. + * @file drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_embest_dmstf4bb.h + * @brief GINPUT Touch low level driver source for the STMPE811 on the Embest DM-STF4BB board. * * @defgroup Mouse Mouse * @ingroup GINPUT @@ -89,4 +89,3 @@ static inline uint16_t read_value(uint16_t port) { #endif /* _GINPUT_LLD_MOUSE_BOARD_H */ /** @} */ - diff --git a/drivers/ginput/touch/STMPE811/stmpe811.h b/drivers/ginput/touch/STMPE811/stmpe811.h new file mode 100644 index 00000000..f17d395b --- /dev/null +++ b/drivers/ginput/touch/STMPE811/stmpe811.h @@ -0,0 +1,100 @@ +/* + 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 // 32-bit +#define STMPE811_REG_TSC_FRACT_XYZ 0x56 +#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 */ +/** @} */