ugfx/drivers/ginput/touch/STMPE811/ginput_lld_mouse_board_embe...

126 lines
3.4 KiB
C
Raw Normal View History

2013-03-07 23:56:59 +00:00
/*
ChibiOS/GFX - Copyright (C) 2012, 2013
Joel Bodenmann aka Tectu <joel@unormal.org>
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 <http://www.gnu.org/licenses/>.
*/
/**
* @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.
2013-03-07 23:56:59 +00:00
*
* @defgroup Mouse Mouse
* @ingroup GINPUT
* @{
*/
#ifndef _GINPUT_LLD_MOUSE_BOARD_H
#define _GINPUT_LLD_MOUSE_BOARD_H
2013-03-19 21:59:04 +00:00
static const I2CConfig i2ccfg = {
2013-03-07 23:56:59 +00:00
OPMODE_I2C,
400000,
FAST_DUTY_CYCLE_2,
};
/**
* @brief Initialise the board for the touch.
*
* @notapi
*/
2013-03-19 21:59:04 +00:00
static void init_board(void) {
palSetPadMode(GPIOC, 13, PAL_MODE_INPUT | PAL_STM32_PUDR_FLOATING); /* TP IRQ */
palSetPadMode(GPIOB, 8, PAL_MODE_ALTERNATE(4) | PAL_STM32_OTYPE_OPENDRAIN); /* SCL */
palSetPadMode(GPIOB, 9, PAL_MODE_ALTERNATE(4) | PAL_STM32_OTYPE_OPENDRAIN); /* SDA */
2013-03-07 23:56:59 +00:00
2013-03-19 21:59:04 +00:00
i2cStart(&I2CD1, &i2ccfg);
2013-03-07 23:56:59 +00:00
}
/**
* @brief Check whether the surface is currently touched
* @return TRUE if the surface is currently touched
*
* @notapi
*/
static inline bool_t getpin_pressed(void) {
return (!(palReadPad(GPIOC, 13)));
}
/**
2013-03-19 21:59:04 +00:00
* @brief Write a value into a certain register
2013-03-07 23:56:59 +00:00
*
2013-03-19 21:59:04 +00:00
* @param[in] reg The register address
* @param[in] n The amount of bytes (one or two)
* @param[in] val The value
2013-03-07 23:56:59 +00:00
*
* @notapi
*/
2013-03-19 21:59:04 +00:00
static void write_reg(uint8_t reg, uint8_t n, uint16_t val) {
uint8_t txbuf[2];
2013-03-19 21:59:04 +00:00
i2cAcquireBus(&I2CD1);
txbuf[0] = reg;
i2cMasterTransmitTimeout(&I2CD1, STMPE811_ADDR, txbuf, 1, NULL, 0, MS2ST(STMPE811_TIMEOUT));
2013-03-07 23:56:59 +00:00
2013-03-19 21:59:04 +00:00
if(n == 1) {
txbuf[0] = val;
i2cMasterTransmitTimeout(&I2CD1, STMPE811_ADDR, txbuf, 1, NULL, 0, MS2ST(STMPE811_TIMEOUT));
} else if(n == 2) {
2013-03-19 21:59:04 +00:00
txbuf[0] = ((val & 0xFF00) >> 8);
txbuf[1] = (val & 0x00FF);
i2cMasterTransmitTimeout(&I2CD1, STMPE811_ADDR, txbuf, 2, NULL, 0, MS2ST(STMPE811_TIMEOUT));
}
i2cReleaseBus(&I2CD1);
}
2013-03-07 23:56:59 +00:00
/**
2013-03-19 21:59:04 +00:00
* @brief Read the value of a certain register
2013-03-07 23:56:59 +00:00
*
2013-03-19 21:59:04 +00:00
* @param[in] reg The register address
* @param[in] n The amount of bytes (one or two)
2013-03-07 23:56:59 +00:00
*
* @notapi
*/
2013-03-19 21:59:04 +00:00
static uint16_t read_reg(uint8_t reg, uint8_t n) {
uint8_t txbuf[1], rxbuf[2];
uint16_t ret;
rxbuf[0] = 0;
rxbuf[1] = 0;
2013-03-19 21:59:04 +00:00
i2cAcquireBus(&I2CD1);
txbuf[0] = reg;
i2cMasterTransmitTimeout(&I2CD1, STMPE811_ADDR, txbuf, 1, rxbuf, 0, MS2ST(STMPE811_TIMEOUT));
2013-03-19 21:59:04 +00:00
if(n == 1) {
i2cMasterReceiveTimeout(&I2CD1, STMPE811_ADDR, rxbuf, 1, MS2ST(STMPE811_TIMEOUT));
2013-03-19 21:59:04 +00:00
ret = rxbuf[0];
} else if(n == 2) {
i2cMasterReceiveTimeout(&I2CD1, STMPE811_ADDR, rxbuf, 2, MS2ST(STMPE811_TIMEOUT));
2013-03-19 21:59:04 +00:00
ret = ((rxbuf[0] << 8) | (rxbuf[1] & 0xFF));
}
i2cReleaseBus(&I2CD1);
2013-03-19 21:59:04 +00:00
return ret;
2013-03-07 23:56:59 +00:00
}
#endif /* _GINPUT_LLD_MOUSE_BOARD_H */
/** @} */