mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
606fb22e97
This reverts commit 304d9f5172c8c0210e2e29b175e8f68ea8257f69. low power mode changes are causing issues like,delay in reponse to touch , and controller is not recognizing the touch events as its scan rate is also low in low power mode state . since controller is not recognizing the touch in low power mode state , so only way for the controller to come out of low power mode is to do multi-touch and controller responds randomly to one of the touches and comes out of the low power mode. Signed-off-by: Sreenivasulu Chalam Charla <sreeniva@codeaurora.org> Change-Id: I35e0797f819cfbce6630d70af443b96546eacfb5 Signed-off-by: Neha Pandey <nehap@codeaurora.org>
666 lines
17 KiB
C
666 lines
17 KiB
C
/* Header file for:
|
|
* Cypress TrueTouch(TM) Standard Product touchscreen drivers.
|
|
* include/linux/cyttsp.h
|
|
*
|
|
* Copyright (C) 2009, 2010 Cypress Semiconductor, Inc.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* version 2, and only version 2, as published by the
|
|
* Free Software Foundation.
|
|
*
|
|
* This program 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, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*
|
|
* Cypress reserves the right to make changes without further notice
|
|
* to the materials described herein. Cypress does not assume any
|
|
* liability arising out of the application described herein.
|
|
*
|
|
* Contact Cypress Semiconductor at www.cypress.com
|
|
*
|
|
*/
|
|
|
|
|
|
#ifndef __CYTTSP_H__
|
|
#define __CYTTSP_H__
|
|
|
|
#include <linux/input.h>
|
|
#include <linux/timer.h>
|
|
#include <linux/workqueue.h>
|
|
#include <linux/kernel.h>
|
|
#include <linux/delay.h>
|
|
|
|
#include <asm/mach-types.h>
|
|
|
|
#define CYPRESS_TTSP_NAME "cyttsp"
|
|
#define CY_I2C_NAME "cyttsp-i2c"
|
|
#define CY_SPI_NAME "cyttsp-spi"
|
|
|
|
#ifdef CY_DECLARE_GLOBALS
|
|
uint32_t cyttsp_tsdebug;
|
|
module_param_named(tsdebug, cyttsp_tsdebug, uint, 0664);
|
|
uint32_t cyttsp_tsxdebug;
|
|
module_param_named(tsxdebug, cyttsp_tsxdebug, uint, 0664);
|
|
|
|
uint32_t cyttsp_disable_touch;
|
|
module_param_named(disable_touch, cyttsp_disable_touch, uint, 0664);
|
|
#else
|
|
extern uint32_t cyttsp_tsdebug;
|
|
extern uint32_t cyttsp_tsxdebug;
|
|
extern uint32_t cyttsp_disable_touch;
|
|
#endif
|
|
|
|
|
|
|
|
/******************************************************************************
|
|
* Global Control, Used to control the behavior of the driver
|
|
*/
|
|
|
|
/* defines for Gen2 (Txx2xx); Gen3 (Txx3xx)
|
|
* use these defines to set cyttsp_platform_data.gen in board config file
|
|
*/
|
|
#define CY_GEN2 2
|
|
#define CY_GEN3 3
|
|
|
|
/* define for using I2C driver
|
|
*/
|
|
#define CY_USE_I2C_DRIVER
|
|
|
|
/* defines for using SPI driver */
|
|
/*
|
|
#define CY_USE_SPI_DRIVER
|
|
*/
|
|
#define CY_SPI_DFLT_SPEED_HZ 1000000
|
|
#define CY_SPI_MAX_SPEED_HZ 4000000
|
|
#define CY_SPI_SPEED_HZ CY_SPI_DFLT_SPEED_HZ
|
|
#define CY_SPI_BITS_PER_WORD 8
|
|
#define CY_SPI_DAV 139 /* set correct gpio id */
|
|
#define CY_SPI_BUFSIZE 512
|
|
|
|
/* Voltage and Current ratings */
|
|
#define CY_TMA300_VTG_MAX_UV 5500000
|
|
#define CY_TMA300_VTG_MIN_UV 1710000
|
|
#define CY_TMA300_CURR_24HZ_UA 17500
|
|
#define CY_TMA300_SLEEP_CURR_UA 10
|
|
#define CY_I2C_VTG_MAX_UV 1800000
|
|
#define CY_I2C_VTG_MIN_UV 1800000
|
|
#define CY_I2C_CURR_UA 9630
|
|
#define CY_I2C_SLEEP_CURR_UA 10
|
|
|
|
|
|
/* define for inclusion of TTSP App Update Load File
|
|
* use this define if update to the TTSP Device is desired
|
|
*/
|
|
/*
|
|
#define CY_INCLUDE_LOAD_FILE
|
|
*/
|
|
|
|
/* define if force new load file for bootloader load */
|
|
/*
|
|
#define CY_FORCE_FW_UPDATE
|
|
*/
|
|
|
|
/* undef for production use */
|
|
/*
|
|
#define CY_USE_DEBUG
|
|
*/
|
|
|
|
/* undef for irq use; use this define in the board configuration file */
|
|
/*
|
|
#define CY_USE_TIMER
|
|
*/
|
|
|
|
/* undef to allow use of extra debug capability */
|
|
/*
|
|
#define CY_ALLOW_EXTRA_DEBUG
|
|
*/
|
|
|
|
/* undef to remove additional debug prints */
|
|
/*
|
|
#define CY_USE_EXTRA_DEBUG
|
|
*/
|
|
|
|
/* undef to remove additional debug prints */
|
|
/*
|
|
#define CY_USE_EXTRA_DEBUG1
|
|
*/
|
|
|
|
/* undef to use operational touch timer jiffies; else use test jiffies */
|
|
/*
|
|
*/
|
|
#define CY_USE_TIMER_DEBUG
|
|
|
|
/* define to use canned test data */
|
|
/*
|
|
#define CY_USE_TEST_DATA
|
|
*/
|
|
|
|
/* define if gesture signaling is used
|
|
* and which gesture groups to use
|
|
*/
|
|
/*
|
|
#define CY_USE_GEST
|
|
#define CY_USE_GEST_GRP1
|
|
#define CY_USE_GEST_GRP2
|
|
#define CY_USE_GEST_GRP3
|
|
#define CY_USE_GEST_GRP4
|
|
*/
|
|
/* Active distance in pixels for a gesture to be reported
|
|
* if set to 0, then all gesture movements are reported
|
|
*/
|
|
#define CY_ACT_DIST_DFLT 8
|
|
#define CY_ACT_DIST CY_ACT_DIST_DFLT
|
|
|
|
/* define if MT signals are desired */
|
|
/*
|
|
*/
|
|
#define CY_USE_MT_SIGNALS
|
|
|
|
/* define if MT tracking id signals are used */
|
|
/*
|
|
#define CY_USE_MT_TRACK_ID
|
|
*/
|
|
|
|
/* define if ST signals are required */
|
|
/*
|
|
*/
|
|
#define CY_USE_ST_SIGNALS
|
|
|
|
/* define to send handshake to device */
|
|
/*
|
|
*/
|
|
#define CY_USE_HNDSHK
|
|
|
|
/* define if log all raw motion signals to a sysfs file */
|
|
/*
|
|
#define CY_LOG_TO_FILE
|
|
*/
|
|
|
|
|
|
/* End of the Global Control section
|
|
******************************************************************************
|
|
*/
|
|
#define CY_DIFF(m, n) ((m) != (n))
|
|
|
|
#ifdef CY_LOG_TO_FILE
|
|
#define cyttsp_openlog() /* use sysfs */
|
|
#else
|
|
#define cyttsp_openlog()
|
|
#endif /* CY_LOG_TO_FILE */
|
|
|
|
/* see kernel.h for pr_xxx def'ns */
|
|
#define cyttsp_info(f, a...) pr_info("%s:" f, __func__ , ## a)
|
|
#define cyttsp_error(f, a...) pr_err("%s:" f, __func__ , ## a)
|
|
#define cyttsp_alert(f, a...) pr_alert("%s:" f, __func__ , ## a)
|
|
|
|
#ifdef CY_USE_DEBUG
|
|
#define cyttsp_debug(f, a...) pr_alert("%s:" f, __func__ , ## a)
|
|
#else
|
|
#define cyttsp_debug(f, a...) {if (cyttsp_tsdebug) \
|
|
pr_alert("%s:" f, __func__ , ## a); }
|
|
#endif /* CY_USE_DEBUG */
|
|
|
|
#ifdef CY_ALLOW_EXTRA_DEBUG
|
|
#ifdef CY_USE_EXTRA_DEBUG
|
|
#define cyttsp_xdebug(f, a...) pr_alert("%s:" f, __func__ , ## a)
|
|
#else
|
|
#define cyttsp_xdebug(f, a...) {if (cyttsp_tsxdebug) \
|
|
pr_alert("%s:" f, __func__ , ## a); }
|
|
#endif /* CY_USE_EXTRA_DEBUG */
|
|
|
|
#ifdef CY_USE_EXTRA_DEBUG1
|
|
#define cyttsp_xdebug1(f, a...) pr_alert("%s:" f, __func__ , ## a)
|
|
#else
|
|
#define cyttsp_xdebug1(f, a...)
|
|
#endif /* CY_USE_EXTRA_DEBUG1 */
|
|
#else
|
|
#define cyttsp_xdebug(f, a...)
|
|
#define cyttsp_xdebug1(f, a...)
|
|
#endif /* CY_ALLOW_EXTRA_DEBUG */
|
|
|
|
#ifdef CY_USE_TIMER_DEBUG
|
|
#define TOUCHSCREEN_TIMEOUT (msecs_to_jiffies(1000))
|
|
#else
|
|
#define TOUCHSCREEN_TIMEOUT (msecs_to_jiffies(28))
|
|
#endif
|
|
|
|
/* reduce extra signals in MT only build
|
|
* be careful not to lose backward compatibility for pre-MT apps
|
|
*/
|
|
#ifdef CY_USE_ST_SIGNALS
|
|
#define CY_USE_ST 1
|
|
#else
|
|
#define CY_USE_ST 0
|
|
#endif /* CY_USE_ST_SIGNALS */
|
|
|
|
/* rely on kernel input.h to define Multi-Touch capability */
|
|
/* if input.h defines the Multi-Touch signals, then use MT */
|
|
#if defined(ABS_MT_TOUCH_MAJOR) && defined(CY_USE_MT_SIGNALS)
|
|
#define CY_USE_MT 1
|
|
#define CY_MT_SYNC(input) input_mt_sync(input)
|
|
#else
|
|
#define CY_USE_MT 0
|
|
#define CY_MT_SYNC(input)
|
|
/* the following includes are provided to ensure a compile;
|
|
* the code that compiles with these defines will not be executed if
|
|
* the CY_USE_MT is properly used in the platform structure init
|
|
*/
|
|
#ifndef ABS_MT_TOUCH_MAJOR
|
|
#define ABS_MT_TOUCH_MAJOR 0x30 /* touching ellipse */
|
|
#define ABS_MT_TOUCH_MINOR 0x31 /* (omit if circular) */
|
|
#define ABS_MT_WIDTH_MAJOR 0x32 /* approaching ellipse */
|
|
#define ABS_MT_WIDTH_MINOR 0x33 /* (omit if circular) */
|
|
#define ABS_MT_ORIENTATION 0x34 /* Ellipse orientation */
|
|
#define ABS_MT_POSITION_X 0x35 /* Center X ellipse position */
|
|
#define ABS_MT_POSITION_Y 0x36 /* Center Y ellipse position */
|
|
#define ABS_MT_TOOL_TYPE 0x37 /* Type of touching device */
|
|
#define ABS_MT_BLOB_ID 0x38 /* Group set of pkts as blob */
|
|
#endif /* ABS_MT_TOUCH_MAJOR */
|
|
#endif /* ABS_MT_TOUCH_MAJOR and CY_USE_MT_SIGNALS */
|
|
#if defined(ABS_MT_TRACKING_ID) && defined(CY_USE_MT_TRACK_ID)
|
|
#define CY_USE_TRACKING_ID 1
|
|
#else
|
|
#define CY_USE_TRACKING_ID 0
|
|
/* define only if not defined already by system;
|
|
* value based on linux kernel 2.6.30.10
|
|
*/
|
|
#ifndef ABS_MT_TRACKING_ID
|
|
#define ABS_MT_TRACKING_ID (ABS_MT_BLOB_ID+1)
|
|
#endif
|
|
#endif /* ABS_MT_TRACKING_ID */
|
|
|
|
#define CY_USE_DEEP_SLEEP_SEL 0x80
|
|
#define CY_USE_LOW_POWER_SEL 0x01
|
|
|
|
#ifdef CY_USE_TEST_DATA
|
|
#define cyttsp_testdat(ray1, ray2, sizeofray) \
|
|
{ \
|
|
int i; \
|
|
u8 *up1 = (u8 *)ray1; \
|
|
u8 *up2 = (u8 *)ray2; \
|
|
for (i = 0; i < sizeofray; i++) { \
|
|
up1[i] = up2[i]; \
|
|
} \
|
|
}
|
|
#else
|
|
#define cyttsp_testdat(xy, test_xy, sizeofray)
|
|
#endif /* CY_USE_TEST_DATA */
|
|
|
|
/* helper macros */
|
|
#define GET_NUM_TOUCHES(x) ((x) & 0x0F)
|
|
#define GET_TOUCH1_ID(x) (((x) & 0xF0) >> 4)
|
|
#define GET_TOUCH2_ID(x) ((x) & 0x0F)
|
|
#define GET_TOUCH3_ID(x) (((x) & 0xF0) >> 4)
|
|
#define GET_TOUCH4_ID(x) ((x) & 0x0F)
|
|
#define IS_LARGE_AREA(x) (((x) & 0x10) >> 4)
|
|
#define FLIP_DATA_FLAG 0x01
|
|
#define REVERSE_X_FLAG 0x02
|
|
#define REVERSE_Y_FLAG 0x04
|
|
#define FLIP_DATA(flags) ((flags) & FLIP_DATA_FLAG)
|
|
#define REVERSE_X(flags) ((flags) & REVERSE_X_FLAG)
|
|
#define REVERSE_Y(flags) ((flags) & REVERSE_Y_FLAG)
|
|
#define FLIP_XY(x, y) { \
|
|
u16 tmp; \
|
|
tmp = (x); \
|
|
(x) = (y); \
|
|
(y) = tmp; \
|
|
}
|
|
#define INVERT_X(x, xmax) ((xmax) - (x))
|
|
#define INVERT_Y(y, maxy) ((maxy) - (y))
|
|
#define SET_HSTMODE(reg, mode) ((reg) & (mode))
|
|
#define GET_HSTMODE(reg) ((reg & 0x70) >> 4)
|
|
#define GET_BOOTLOADERMODE(reg) ((reg & 0x10) >> 4)
|
|
|
|
/* constant definitions */
|
|
/* maximum number of concurrent ST track IDs */
|
|
#define CY_NUM_ST_TCH_ID 2
|
|
|
|
/* maximum number of concurrent MT track IDs */
|
|
#define CY_NUM_MT_TCH_ID 4
|
|
|
|
/* maximum number of track IDs */
|
|
#define CY_NUM_TRK_ID 16
|
|
|
|
#define CY_NTCH 0 /* no touch (lift off) */
|
|
#define CY_TCH 1 /* active touch (touchdown) */
|
|
#define CY_ST_FNGR1_IDX 0
|
|
#define CY_ST_FNGR2_IDX 1
|
|
#define CY_MT_TCH1_IDX 0
|
|
#define CY_MT_TCH2_IDX 1
|
|
#define CY_MT_TCH3_IDX 2
|
|
#define CY_MT_TCH4_IDX 3
|
|
#define CY_XPOS 0
|
|
#define CY_YPOS 1
|
|
#define CY_IGNR_TCH (-1)
|
|
#define CY_SMALL_TOOL_WIDTH 10
|
|
#define CY_LARGE_TOOL_WIDTH 255
|
|
#define CY_REG_BASE 0x00
|
|
#define CY_REG_GEST_SET 0x1E
|
|
#define CY_REG_ACT_INTRVL 0x1D
|
|
#define CY_REG_TCH_TMOUT (CY_REG_ACT_INTRVL+1)
|
|
#define CY_REG_LP_INTRVL (CY_REG_TCH_TMOUT+1)
|
|
#define CY_SOFT_RESET ((1 << 0))
|
|
#define CY_DEEP_SLEEP ((1 << 1))
|
|
#define CY_LOW_POWER ((1 << 2))
|
|
#define CY_MAXZ 255
|
|
#define CY_OK 0
|
|
#define CY_INIT 1
|
|
#define CY_DLY_DFLT 10 /* ms */
|
|
#define CY_DLY_SYSINFO 20 /* ms */
|
|
#define CY_DLY_BL 300
|
|
#define CY_DLY_DNLOAD 100 /* ms */
|
|
#define CY_NUM_RETRY 4 /* max num touch data read */
|
|
|
|
/* handshake bit in the hst_mode reg */
|
|
#define CY_HNDSHK_BIT 0x80
|
|
#ifdef CY_USE_HNDSHK
|
|
#define CY_SEND_HNDSHK 1
|
|
#else
|
|
#define CY_SEND_HNDSHK 0
|
|
#endif
|
|
|
|
/* Bootloader File 0 offset */
|
|
#define CY_BL_FILE0 0x00
|
|
|
|
/* Bootloader command directive */
|
|
#define CY_BL_CMD 0xFF
|
|
|
|
/* Bootloader Initiate Bootload */
|
|
#define CY_BL_INIT_LOAD 0x38
|
|
|
|
/* Bootloader Write a Block */
|
|
#define CY_BL_WRITE_BLK 0x39
|
|
|
|
/* Bootloader Terminate Bootload */
|
|
#define CY_BL_TERMINATE 0x3B
|
|
|
|
/* Bootloader Exit and Verify Checksum command */
|
|
#define CY_BL_EXIT 0xA5
|
|
|
|
/* Bootloader default keys */
|
|
#define CY_BL_KEY0 0x00
|
|
#define CY_BL_KEY1 0x01
|
|
#define CY_BL_KEY2 0x02
|
|
#define CY_BL_KEY3 0x03
|
|
#define CY_BL_KEY4 0x04
|
|
#define CY_BL_KEY5 0x05
|
|
#define CY_BL_KEY6 0x06
|
|
#define CY_BL_KEY7 0x07
|
|
|
|
/* Active Power state scanning/processing refresh interval */
|
|
#define CY_ACT_INTRVL_DFLT 0x00
|
|
|
|
/* touch timeout for the Active power */
|
|
#define CY_TCH_TMOUT_DFLT 0xFF
|
|
|
|
/* Low Power state scanning/processing refresh interval */
|
|
#define CY_LP_INTRVL_DFLT 0x0A
|
|
|
|
#define CY_IDLE_STATE 0
|
|
#define CY_ACTIVE_STATE 1
|
|
#define CY_LOW_PWR_STATE 2
|
|
#define CY_SLEEP_STATE 3
|
|
|
|
/* device mode bits */
|
|
#define CY_OP_MODE 0x00
|
|
#define CY_SYSINFO_MODE 0x10
|
|
|
|
/* power mode select bits */
|
|
#define CY_SOFT_RESET_MODE 0x01 /* return to Bootloader mode */
|
|
#define CY_DEEP_SLEEP_MODE 0x02
|
|
#define CY_LOW_PWR_MODE 0x04
|
|
|
|
#define CY_NUM_KEY 8
|
|
|
|
#ifdef CY_USE_GEST
|
|
#define CY_USE_GESTURES 1
|
|
#else
|
|
#define CY_USE_GESTURES 0
|
|
#endif /* CY_USE_GESTURE_SIGNALS */
|
|
|
|
#ifdef CY_USE_GEST_GRP1
|
|
#define CY_GEST_GRP1 0x10
|
|
#else
|
|
#define CY_GEST_GRP1 0x00
|
|
#endif /* CY_USE_GEST_GRP1 */
|
|
#ifdef CY_USE_GEST_GRP2
|
|
#define CY_GEST_GRP2 0x20
|
|
#else
|
|
#define CY_GEST_GRP2 0x00
|
|
#endif /* CY_USE_GEST_GRP2 */
|
|
#ifdef CY_USE_GEST_GRP3
|
|
#define CY_GEST_GRP3 0x40
|
|
#else
|
|
#define CY_GEST_GRP3 0x00
|
|
#endif /* CY_USE_GEST_GRP3 */
|
|
#ifdef CY_USE_GEST_GRP4
|
|
#define CY_GEST_GRP4 0x80
|
|
#else
|
|
#define CY_GEST_GRP4 0x00
|
|
#endif /* CY_USE_GEST_GRP4 */
|
|
|
|
struct cyttsp_regulator {
|
|
const char *name;
|
|
u32 max_uV;
|
|
u32 min_uV;
|
|
u32 hpm_load_uA;
|
|
u32 lpm_load_uA;
|
|
};
|
|
|
|
struct cyttsp_platform_data {
|
|
u32 panel_maxx;
|
|
u32 panel_maxy;
|
|
u32 disp_resx;
|
|
u32 disp_resy;
|
|
u32 disp_minx;
|
|
u32 disp_miny;
|
|
u32 disp_maxx;
|
|
u32 disp_maxy;
|
|
u8 correct_fw_ver;
|
|
u32 flags;
|
|
u8 gen;
|
|
u8 use_st;
|
|
u8 use_mt;
|
|
u8 use_hndshk;
|
|
u8 use_trk_id;
|
|
u8 use_sleep;
|
|
u8 use_gestures;
|
|
u8 gest_set;
|
|
u8 act_intrvl;
|
|
u8 tch_tmout;
|
|
u8 lp_intrvl;
|
|
u8 power_state;
|
|
bool wakeup;
|
|
int sleep_gpio;
|
|
int resout_gpio;
|
|
int irq_gpio;
|
|
struct cyttsp_regulator *regulator_info;
|
|
u8 num_regulators;
|
|
const char *fw_fname;
|
|
bool disable_ghost_det;
|
|
#ifdef CY_USE_I2C_DRIVER
|
|
s32 (*init)(struct i2c_client *client);
|
|
s32 (*resume)(struct i2c_client *client);
|
|
s32 (*suspend)(struct i2c_client *client);
|
|
#endif
|
|
#ifdef CY_USE_SPI_DRIVER
|
|
s32 (*init)(struct spi_device *spi);
|
|
s32 (*resume)(struct spi_device *spi);
|
|
#endif
|
|
};
|
|
|
|
/* TrueTouch Standard Product Gen3 (Txx3xx) interface definition */
|
|
struct cyttsp_gen3_xydata_t {
|
|
u8 hst_mode;
|
|
u8 tt_mode;
|
|
u8 tt_stat;
|
|
u16 x1 __attribute__ ((packed));
|
|
u16 y1 __attribute__ ((packed));
|
|
u8 z1;
|
|
u8 touch12_id;
|
|
u16 x2 __attribute__ ((packed));
|
|
u16 y2 __attribute__ ((packed));
|
|
u8 z2;
|
|
u8 gest_cnt;
|
|
u8 gest_id;
|
|
u16 x3 __attribute__ ((packed));
|
|
u16 y3 __attribute__ ((packed));
|
|
u8 z3;
|
|
u8 touch34_id;
|
|
u16 x4 __attribute__ ((packed));
|
|
u16 y4 __attribute__ ((packed));
|
|
u8 z4;
|
|
u8 tt_undef[3];
|
|
u8 gest_set;
|
|
u8 tt_reserved;
|
|
};
|
|
|
|
/* TrueTouch Standard Product Gen2 (Txx2xx) interface definition */
|
|
#define CY_GEN2_NOTOUCH 0x03 /* Both touches removed */
|
|
#define CY_GEN2_GHOST 0x02 /* ghost */
|
|
#define CY_GEN2_2TOUCH 0x03 /* 2 touch; no ghost */
|
|
#define CY_GEN2_1TOUCH 0x01 /* 1 touch only */
|
|
#define CY_GEN2_TOUCH2 0x01 /* 1st touch removed;
|
|
* 2nd touch remains */
|
|
struct cyttsp_gen2_xydata_t {
|
|
u8 hst_mode;
|
|
u8 tt_mode;
|
|
u8 tt_stat;
|
|
u16 x1 __attribute__ ((packed));
|
|
u16 y1 __attribute__ ((packed));
|
|
u8 z1;
|
|
u8 evnt_idx;
|
|
u16 x2 __attribute__ ((packed));
|
|
u16 y2 __attribute__ ((packed));
|
|
u8 tt_undef1;
|
|
u8 gest_cnt;
|
|
u8 gest_id;
|
|
u8 tt_undef[14];
|
|
u8 gest_set;
|
|
u8 tt_reserved;
|
|
};
|
|
|
|
/* TTSP System Information interface definition */
|
|
struct cyttsp_sysinfo_data_t {
|
|
u8 hst_mode;
|
|
u8 mfg_cmd;
|
|
u8 mfg_stat;
|
|
u8 cid[3];
|
|
u8 tt_undef1;
|
|
u8 uid[8];
|
|
u8 bl_verh;
|
|
u8 bl_verl;
|
|
u8 tts_verh;
|
|
u8 tts_verl;
|
|
u8 app_idh;
|
|
u8 app_idl;
|
|
u8 app_verh;
|
|
u8 app_verl;
|
|
u8 tt_undef[6];
|
|
u8 act_intrvl;
|
|
u8 tch_tmout;
|
|
u8 lp_intrvl;
|
|
};
|
|
|
|
/* TTSP Bootloader Register Map interface definition */
|
|
#define CY_BL_CHKSUM_OK 0x01
|
|
struct cyttsp_bootloader_data_t {
|
|
u8 bl_file;
|
|
u8 bl_status;
|
|
u8 bl_error;
|
|
u8 blver_hi;
|
|
u8 blver_lo;
|
|
u8 bld_blver_hi;
|
|
u8 bld_blver_lo;
|
|
u8 ttspver_hi;
|
|
u8 ttspver_lo;
|
|
u8 appid_hi;
|
|
u8 appid_lo;
|
|
u8 appver_hi;
|
|
u8 appver_lo;
|
|
u8 cid_0;
|
|
u8 cid_1;
|
|
u8 cid_2;
|
|
};
|
|
|
|
#define cyttsp_wake_data_t cyttsp_gen3_xydata_t
|
|
#ifdef CY_DECLARE_GLOBALS
|
|
#ifdef CY_INCLUDE_LOAD_FILE
|
|
/* this file declares:
|
|
* firmware download block array (cyttsp_fw[]),
|
|
* the number of command block records (cyttsp_fw_records),
|
|
* and the version variables
|
|
*/
|
|
#include "cyttsp_fw.h" /* imports cyttsp_fw[] array */
|
|
#define cyttsp_app_load() 1
|
|
#ifdef CY_FORCE_FW_UPDATE
|
|
#define cyttsp_force_fw_load() 1
|
|
#else
|
|
#define cyttsp_force_fw_load() 0
|
|
#endif
|
|
|
|
#else
|
|
/* the following declarations are to allow
|
|
* some debugging capability
|
|
*/
|
|
unsigned char cyttsp_fw_tts_verh = 0x00;
|
|
unsigned char cyttsp_fw_tts_verl = 0x01;
|
|
unsigned char cyttsp_fw_app_idh = 0x02;
|
|
unsigned char cyttsp_fw_app_idl = 0x03;
|
|
unsigned char cyttsp_fw_app_verh = 0x04;
|
|
unsigned char cyttsp_fw_app_verl = 0x05;
|
|
unsigned char cyttsp_fw_cid_0 = 0x06;
|
|
unsigned char cyttsp_fw_cid_1 = 0x07;
|
|
unsigned char cyttsp_fw_cid_2 = 0x08;
|
|
#define cyttsp_app_load() 0
|
|
#define cyttsp_force_fw_load() 0
|
|
#endif
|
|
#define cyttsp_tts_verh() cyttsp_fw_tts_verh
|
|
#define cyttsp_tts_verl() cyttsp_fw_tts_verl
|
|
#define cyttsp_app_idh() cyttsp_fw_app_idh
|
|
#define cyttsp_app_idl() cyttsp_fw_app_idl
|
|
#define cyttsp_app_verh() cyttsp_fw_app_verh
|
|
#define cyttsp_app_verl() cyttsp_fw_app_verl
|
|
#define cyttsp_cid_0() cyttsp_fw_cid_0
|
|
#define cyttsp_cid_1() cyttsp_fw_cid_1
|
|
#define cyttsp_cid_2() cyttsp_fw_cid_2
|
|
#ifdef CY_USE_TEST_DATA
|
|
static struct cyttsp_gen2_xydata_t tt_gen2_testray[] = {
|
|
{0x00}, {0x00}, {0x04},
|
|
{0x4000}, {0x8000}, {0x80},
|
|
{0x03},
|
|
{0x2000}, {0x1000}, {0x00},
|
|
{0x00},
|
|
{0x00},
|
|
{0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00},
|
|
{0x00},
|
|
{0x00}
|
|
};
|
|
|
|
static struct cyttsp_gen3_xydata_t tt_gen3_testray[] = {
|
|
{0x00}, {0x00}, {0x04},
|
|
{0x4000}, {0x8000}, {0x80},
|
|
{0x12},
|
|
{0x2000}, {0x1000}, {0xA0},
|
|
{0x00}, {0x00},
|
|
{0x8000}, {0x4000}, {0xB0},
|
|
{0x34},
|
|
{0x4000}, {0x1000}, {0xC0},
|
|
{0x00, 0x00, 0x00},
|
|
{0x00},
|
|
{0x00}
|
|
};
|
|
#endif /* CY_USE_TEST_DATA */
|
|
|
|
#else
|
|
extern u8 g_appload_ray[];
|
|
#endif
|
|
|
|
#endif /* __CYTTSP_H__ */
|