3951 lines
		
	
	
	
		
			120 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			3951 lines
		
	
	
	
		
			120 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable file
		
	
	
	
	
| /*
 | |
|  * ILITEK Touch IC driver
 | |
|  *
 | |
|  * Copyright (C) 2011 ILI Technology Corporation.
 | |
|  *
 | |
|  * Author: Dicky Chiang <dicky_chiang@ilitek.com>
 | |
|  *
 | |
|  * 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 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 | |
|  */
 | |
| 
 | |
| #include "ilitek_v3.h"
 | |
| 
 | |
| #if ENABLE_PEN_MODE
 | |
| #define USER_STR_BUFF		(PAGE_SIZE * 2)
 | |
| #define IOCTL_I2C_BUFF		(PAGE_SIZE * 2)
 | |
| #else
 | |
| #define USER_STR_BUFF		PAGE_SIZE
 | |
| #define IOCTL_I2C_BUFF		PAGE_SIZE
 | |
| #endif
 | |
| #define ILITEK_IOCTL_MAGIC	100
 | |
| #define ILITEK_IOCTL_MAXNR	38
 | |
| 
 | |
| #define ILITEK_IOCTL_I2C_WRITE_DATA		_IOWR(ILITEK_IOCTL_MAGIC, 0, u8*)
 | |
| #define ILITEK_IOCTL_I2C_SET_WRITE_LENGTH	_IOWR(ILITEK_IOCTL_MAGIC, 1, int)
 | |
| #define ILITEK_IOCTL_I2C_READ_DATA		_IOWR(ILITEK_IOCTL_MAGIC, 2, u8*)
 | |
| #define ILITEK_IOCTL_I2C_SET_READ_LENGTH	_IOWR(ILITEK_IOCTL_MAGIC, 3, int)
 | |
| 
 | |
| #define ILITEK_IOCTL_TP_HW_RESET		_IOWR(ILITEK_IOCTL_MAGIC, 4, int)
 | |
| #define ILITEK_IOCTL_TP_POWER_SWITCH		_IOWR(ILITEK_IOCTL_MAGIC, 5, int)
 | |
| #define ILITEK_IOCTL_TP_REPORT_SWITCH		_IOWR(ILITEK_IOCTL_MAGIC, 6, int)
 | |
| #define ILITEK_IOCTL_TP_IRQ_SWITCH		_IOWR(ILITEK_IOCTL_MAGIC, 7, int)
 | |
| 
 | |
| #define ILITEK_IOCTL_TP_DEBUG_LEVEL		_IOWR(ILITEK_IOCTL_MAGIC, 8, int)
 | |
| #define ILITEK_IOCTL_TP_FUNC_MODE		_IOWR(ILITEK_IOCTL_MAGIC, 9, int)
 | |
| 
 | |
| #define ILITEK_IOCTL_TP_FW_VER			_IOWR(ILITEK_IOCTL_MAGIC, 10, u8*)
 | |
| #define ILITEK_IOCTL_TP_PL_VER			_IOWR(ILITEK_IOCTL_MAGIC, 11, u8*)
 | |
| #define ILITEK_IOCTL_TP_CORE_VER		_IOWR(ILITEK_IOCTL_MAGIC, 12, u8*)
 | |
| #define ILITEK_IOCTL_TP_DRV_VER			_IOWR(ILITEK_IOCTL_MAGIC, 13, u8*)
 | |
| #define ILITEK_IOCTL_TP_CHIP_ID			_IOWR(ILITEK_IOCTL_MAGIC, 14, u32*)
 | |
| 
 | |
| #define ILITEK_IOCTL_TP_MODE_CTRL		_IOWR(ILITEK_IOCTL_MAGIC, 17, u8*)
 | |
| #define ILITEK_IOCTL_TP_MODE_STATUS		_IOWR(ILITEK_IOCTL_MAGIC, 18, int*)
 | |
| #define ILITEK_IOCTL_ICE_MODE_SWITCH		_IOWR(ILITEK_IOCTL_MAGIC, 19, int)
 | |
| 
 | |
| #define ILITEK_IOCTL_TP_INTERFACE_TYPE		_IOWR(ILITEK_IOCTL_MAGIC, 20, u8*)
 | |
| #define ILITEK_IOCTL_TP_DUMP_FLASH		_IOWR(ILITEK_IOCTL_MAGIC, 21, int)
 | |
| #define ILITEK_IOCTL_TP_FW_UART_CTRL		_IOWR(ILITEK_IOCTL_MAGIC, 22, u8*)
 | |
| #define ILITEK_IOCTL_TP_PANEL_INFO		_IOWR(ILITEK_IOCTL_MAGIC, 23, u32*)
 | |
| #define ILITEK_IOCTL_TP_INFO			_IOWR(ILITEK_IOCTL_MAGIC, 24, u32*)
 | |
| #define ILITEK_IOCTL_WRAPPER_RW 		_IOWR(ILITEK_IOCTL_MAGIC, 25, u8*)
 | |
| #define ILITEK_IOCTL_DDI_WRITE	 		_IOWR(ILITEK_IOCTL_MAGIC, 26, u8*)
 | |
| #define ILITEK_IOCTL_DDI_READ	 		_IOWR(ILITEK_IOCTL_MAGIC, 27, u8*)
 | |
| #define ILITEK_IOCTL_REPORT_RATE_SET	 	_IOWR(ILITEK_IOCTL_MAGIC, 28, u8*)
 | |
| #define ILITEK_IOCTL_REPORT_RATE_GET	 	_IOWR(ILITEK_IOCTL_MAGIC, 29, u8*)
 | |
| #define ILITEK_IOCTL_MP_LCM_OFF_ENV		_IOWR(ILITEK_IOCTL_MAGIC, 30, u8*)
 | |
| #define ILITEK_IOCTL_RELEASE_TOUCH		_IOWR(ILITEK_IOCTL_MAGIC, 31, u8*)
 | |
| #define ILITEK_IOCTL_LCM_STATUS			_IOWR(ILITEK_IOCTL_MAGIC, 32, u8*)
 | |
| #define ILITEK_IOCTL_SLAVE_CTRL			_IOWR(ILITEK_IOCTL_MAGIC, 33, u8*)
 | |
| #define ILITEK_IOCTL_CASCADE_REG_RW		_IOWR(ILITEK_IOCTL_MAGIC, 34, u8*)
 | |
| #define ILITEK_IOCTL_INTERFACE_GET			_IOWR(ILITEK_IOCTL_MAGIC, 35, uint8_t *)
 | |
| #define ILITEK_IOCTL_ICE_MODE_FLAG_SET		_IOWR(ILITEK_IOCTL_MAGIC, 36, uint8_t *)
 | |
| #define ILITEK_IOCTL_RELEASE_PEN		_IOWR(ILITEK_IOCTL_MAGIC, 37, uint8_t *)
 | |
| 
 | |
| #ifdef CONFIG_COMPAT
 | |
| #define ILITEK_COMPAT_IOCTL_I2C_WRITE_DATA		_IOWR(ILITEK_IOCTL_MAGIC, 0, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_I2C_SET_WRITE_LENGTH	_IOWR(ILITEK_IOCTL_MAGIC, 1, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_I2C_READ_DATA		_IOWR(ILITEK_IOCTL_MAGIC, 2, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_I2C_SET_READ_LENGTH		_IOWR(ILITEK_IOCTL_MAGIC, 3, compat_uptr_t)
 | |
| 
 | |
| #define ILITEK_COMPAT_IOCTL_TP_HW_RESET			_IOWR(ILITEK_IOCTL_MAGIC, 4, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_POWER_SWITCH		_IOWR(ILITEK_IOCTL_MAGIC, 5, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_REPORT_SWITCH		_IOWR(ILITEK_IOCTL_MAGIC, 6, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_IRQ_SWITCH		_IOWR(ILITEK_IOCTL_MAGIC, 7, compat_uptr_t)
 | |
| 
 | |
| #define ILITEK_COMPAT_IOCTL_TP_DEBUG_LEVEL		_IOWR(ILITEK_IOCTL_MAGIC, 8, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_FUNC_MODE		_IOWR(ILITEK_IOCTL_MAGIC, 9, compat_uptr_t)
 | |
| 
 | |
| #define ILITEK_COMPAT_IOCTL_TP_FW_VER			_IOWR(ILITEK_IOCTL_MAGIC, 10, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_PL_VER			_IOWR(ILITEK_IOCTL_MAGIC, 11, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_CORE_VER			_IOWR(ILITEK_IOCTL_MAGIC, 12, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_DRV_VER			_IOWR(ILITEK_IOCTL_MAGIC, 13, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_CHIP_ID			_IOWR(ILITEK_IOCTL_MAGIC, 14, compat_uptr_t)
 | |
| 
 | |
| #define ILITEK_COMPAT_IOCTL_TP_MODE_CTRL		_IOWR(ILITEK_IOCTL_MAGIC, 17, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_MODE_STATUS		_IOWR(ILITEK_IOCTL_MAGIC, 18, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_ICE_MODE_SWITCH		_IOWR(ILITEK_IOCTL_MAGIC, 19, compat_uptr_t)
 | |
| 
 | |
| #define ILITEK_COMPAT_IOCTL_TP_INTERFACE_TYPE		_IOWR(ILITEK_IOCTL_MAGIC, 20, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_DUMP_FLASH		_IOWR(ILITEK_IOCTL_MAGIC, 21, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_FW_UART_CTRL		_IOWR(ILITEK_IOCTL_MAGIC, 22, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_PANEL_INFO		_IOWR(ILITEK_IOCTL_MAGIC, 23, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_TP_INFO			_IOWR(ILITEK_IOCTL_MAGIC, 24, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_WRAPPER_RW			_IOWR(ILITEK_IOCTL_MAGIC, 25, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_DDI_WRITE	 		_IOWR(ILITEK_IOCTL_MAGIC, 26, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_DDI_READ	 		_IOWR(ILITEK_IOCTL_MAGIC, 27, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_REPORT_RATE_SET 		_IOWR(ILITEK_IOCTL_MAGIC, 28, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_REPORT_RATE_GET 		_IOWR(ILITEK_IOCTL_MAGIC, 29, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_MP_LCM_OFF_ENV 		_IOWR(ILITEK_IOCTL_MAGIC, 30, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_RELEASE_TOUCH		_IOWR(ILITEK_IOCTL_MAGIC, 31, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_LCM_STATUS			_IOWR(ILITEK_IOCTL_MAGIC, 32, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_SLAVE_CTRL			_IOWR(ILITEK_IOCTL_MAGIC, 33, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_CASCADE_REG_RW		_IOWR(ILITEK_IOCTL_MAGIC, 34, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_INTERFACE_GET			_IOWR(ILITEK_IOCTL_MAGIC, 35, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_ICE_MODE_FLAG_SET		_IOWR(ILITEK_IOCTL_MAGIC, 36, compat_uptr_t)
 | |
| #define ILITEK_COMPAT_IOCTL_RELEASE_PEN  		_IOWR(ILITEK_IOCTL_MAGIC, 37, compat_uptr_t)
 | |
| #endif
 | |
| 
 | |
| struct record_state {
 | |
| 	u8 touch_palm_state_e : 2;
 | |
| 	u8 app_an_statu_e : 3;
 | |
| 	u8 app_sys_check_bg_abnormal : 1;
 | |
| 	u8 g_b_wrong_bg : 1;
 | |
| };
 | |
| 
 | |
| static unsigned char g_user_buf[USER_STR_BUFF] = {0};
 | |
| 
 | |
| int ili_str2hex(char *str)
 | |
| {
 | |
| 	int strlen, result, intermed, intermedtop;
 | |
| 	char *s = str;
 | |
| 
 | |
| 	while (*s != 0x0) {
 | |
| 		s++;
 | |
| 	}
 | |
| 
 | |
| 	strlen = (int)(s - str);
 | |
| 	s = str;
 | |
| 	if (*s != 0x30) {
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	s++;
 | |
| 
 | |
| 	if (*s != 0x78 && *s != 0x58) {
 | |
| 		return -1;
 | |
| 	}
 | |
| 	s++;
 | |
| 
 | |
| 	strlen = strlen - 3;
 | |
| 	result = 0;
 | |
| 	while (*s != 0x0) {
 | |
| 		intermed = *s & 0x0f;
 | |
| 		intermedtop = *s & 0xf0;
 | |
| 		if (intermedtop == 0x60 || intermedtop == 0x40) {
 | |
| 			intermed += 0x09;
 | |
| 		}
 | |
| 		intermed = intermed << (strlen << 2);
 | |
| 		result = result | intermed;
 | |
| 		strlen -= 1;
 | |
| 		s++;
 | |
| 	}
 | |
| 	return result;
 | |
| }
 | |
| 
 | |
| int ili_katoi(char *str)
 | |
| {
 | |
| 	int result = 0;
 | |
| 	unsigned int digit;
 | |
| 	int sign;
 | |
| 
 | |
| 	if (*str == '-') {
 | |
| 		sign = 1;
 | |
| 		str += 1;
 | |
| 	} else {
 | |
| 		sign = 0;
 | |
| 		if (*str == '+') {
 | |
| 			str += 1;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	for (;; str += 1) {
 | |
| 		digit = *str - '0';
 | |
| 		if (digit > 9)
 | |
| 			break;
 | |
| 		result = (10 * result) + digit;
 | |
| 	}
 | |
| 
 | |
| 	if (sign) {
 | |
| 		return -result;
 | |
| 	}
 | |
| 	return result;
 | |
| }
 | |
| 
 | |
| int file_write(struct file_buffer *file, bool new_open)
 | |
| {
 | |
| #if GENERIC_KERNEL_IMAGE
 | |
| 	ILI_ERR("GKI version not allow drivers to use filp_open\n");
 | |
| 	return -1;
 | |
| #else
 | |
| 	struct file *f = NULL;
 | |
| #if LINUX_VERSION_CODE <= KERNEL_VERSION(4, 14, 0)
 | |
| 	mm_segment_t fs;
 | |
| #endif
 | |
| 	loff_t pos;
 | |
| 
 | |
| 	if (file->ptr == NULL) {
 | |
| 		ILI_ERR("str is invaild\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	if (strlen(file->fname) == 0) {
 | |
| 		ILI_ERR("file name is invaild\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	if (file->flen >= file->max_size) {
 | |
| 		ILI_ERR("The length saved to file is too long !\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	if (new_open)
 | |
| 		f = filp_open(file->fname, O_WRONLY | O_CREAT | O_TRUNC, 644);
 | |
| 	else
 | |
| 		f = filp_open(file->fname, O_WRONLY | O_CREAT | O_APPEND, 644);
 | |
| 
 | |
| 	if (ERR_ALLOC_MEM(f)) {
 | |
| 		ILI_ERR("Failed to open %s file\n", file->fname);
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	pos = 0;
 | |
| #if LINUX_VERSION_CODE <= KERNEL_VERSION(4, 14, 0)
 | |
| 	fs = get_fs();
 | |
| 	set_fs(KERNEL_DS);
 | |
| 	vfs_write(f, file->ptr, file->wlen, &pos);
 | |
| 	set_fs(fs);
 | |
| #else
 | |
| 	kernel_write(f, file->ptr, file->wlen, &pos);
 | |
| #endif
 | |
| 	filp_close(f, NULL);
 | |
| 	return 0;
 | |
| #endif
 | |
| }
 | |
| 
 | |
| static int ilitek_debug_node_buff_control(bool open)
 | |
| {
 | |
| 	int i, ret;
 | |
| 
 | |
| 	ilits->dnp = open;
 | |
| 
 | |
| 	ILI_INFO("Debug buf ctrl = %s\n", ilits->dnp ? "Enabled" : "Disabled");
 | |
| 
 | |
| 	if (open) {
 | |
| 		ilits->dlnp = DISABLE;
 | |
| 		ilits->dbf = 0;
 | |
| 		ilits->odi = 0;
 | |
| 		if (!ERR_ALLOC_MEM(ilits->dbl)) {
 | |
| 			for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 				ilits->dbl[i].mark = false;
 | |
| 				ipio_kfree((void **)&ilits->dbl[i].data);
 | |
| 			}
 | |
| 			ipio_kfree((void **)&ilits->dbl);
 | |
| 		}
 | |
| 
 | |
| 		ilits->dbl = kzalloc(TR_BUF_LIST_SIZE * sizeof(*ilits->dbl), GFP_KERNEL);
 | |
| 		if (ERR_ALLOC_MEM(ilits->dbl)) {
 | |
| 			ILI_ERR("Failed to allocate ilits->dbl mem, %ld\n", PTR_ERR(ilits->dbl));
 | |
| 			ret = -ENOMEM;
 | |
| 			goto out;
 | |
| 		}
 | |
| 
 | |
| 		for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 			ilits->dbl[i].mark = false;
 | |
| 			ilits->dbl[i].data = kzalloc(TR_BUF_SIZE * sizeof(unsigned char), GFP_KERNEL);
 | |
| 			if (ERR_ALLOC_MEM(ilits->dbl[i].data)) {
 | |
| 				ILI_ERR("Failed to allocate dbl[%d] mem, %ld\n", i, PTR_ERR(ilits->dbl[i].data));
 | |
| 				ret = -ENOMEM;
 | |
| 				goto out;
 | |
| 			}
 | |
| 		}
 | |
| 		ilits->outputStrArr = vmalloc(TR_BUF_SIZE * 2);
 | |
| 		return 0;
 | |
| 	}
 | |
| out:
 | |
| 	ilits->dnp = DISABLE;
 | |
| 	if (!ERR_ALLOC_MEM(ilits->dbl)) {
 | |
| 		for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 			ilits->dbl[i].mark = false;
 | |
| 			ipio_kfree((void **)&ilits->dbl[i].data);
 | |
| 		}
 | |
| 	}
 | |
| 	ipio_kfree((void **)&ilits->dbl);
 | |
| 	ipio_vfree((void **)&ilits->outputStrArr);
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static int ilitek_debug_all_node_buff_control(bool open)
 | |
| {
 | |
| 	int i, ret;
 | |
| 
 | |
| 	ilits->dlnp = open;
 | |
| 
 | |
| 	ILI_INFO("Debug all buf ctrl = %s\n", ilits->dlnp ? "Enabled" : "Disabled");
 | |
| 
 | |
| 	if (open) {
 | |
| 		ilits->dnp = DISABLE;
 | |
| 		ilits->dbf = 0;
 | |
| 		ilits->odi = 0;
 | |
| 		/* ping pong buffer*/
 | |
| 		/* debug buffer A*/
 | |
| 		if (!ERR_ALLOC_MEM(ilits->dbf_a)) {
 | |
| 			for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 				ilits->dbf_a[i].mark = false;
 | |
| 				ipio_kfree((void **)&ilits->dbf_a[i].data);
 | |
| 			}
 | |
| 			ipio_kfree((void **)&ilits->dbf_a);
 | |
| 		}
 | |
| 
 | |
| 		ilits->dbf_a = kzalloc(TR_BUF_LIST_SIZE * sizeof(*ilits->dbf_a), GFP_KERNEL);
 | |
| 		if (ERR_ALLOC_MEM(ilits->dbf_a)) {
 | |
| 			ILI_ERR("Failed to allocate ilits->dbf_a mem, %ld\n", PTR_ERR(ilits->dbf_a));
 | |
| 			ret = -ENOMEM;
 | |
| 			goto out;
 | |
| 		}
 | |
| 
 | |
| 		for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 			ilits->dbf_a[i].mark = false;
 | |
| 			ilits->dbf_a[i].data = kzalloc(TR_BUF_SIZE * sizeof(unsigned char), GFP_KERNEL);
 | |
| 			if (ERR_ALLOC_MEM(ilits->dbf_a[i].data)) {
 | |
| 				ILI_ERR("Failed to allocate dbl_a[%d] mem, %ld\n", i, PTR_ERR(ilits->dbf_a[i].data));
 | |
| 				ret = -ENOMEM;
 | |
| 				goto out;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		/* debug buffer B */
 | |
| 		if (!ERR_ALLOC_MEM(ilits->dbf_b)) {
 | |
| 			for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 				ilits->dbf_b[i].mark = false;
 | |
| 				ipio_kfree((void **)&ilits->dbf_b[i].data);
 | |
| 			}
 | |
| 			ipio_kfree((void **)&ilits->dbf_b);
 | |
| 		}
 | |
| 
 | |
| 		ilits->dbf_b = kzalloc(TR_BUF_LIST_SIZE * sizeof(*ilits->dbf_b), GFP_KERNEL);
 | |
| 		if (ERR_ALLOC_MEM(ilits->dbf_b)) {
 | |
| 			ILI_ERR("Failed to allocate ilits->dbf_b mem, %ld\n", PTR_ERR(ilits->dbf_b));
 | |
| 			ret = -ENOMEM;
 | |
| 			goto out;
 | |
| 		}
 | |
| 
 | |
| 		for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 			ilits->dbf_b[i].mark = false;
 | |
| 			ilits->dbf_b[i].data = kzalloc(TR_BUF_SIZE * sizeof(unsigned char), GFP_KERNEL);
 | |
| 			if (ERR_ALLOC_MEM(ilits->dbf_b[i].data)) {
 | |
| 				ILI_ERR("Failed to allocate dbl_b[%d] mem, %ld\n", i, PTR_ERR(ilits->dbf_b[i].data));
 | |
| 				ret = -ENOMEM;
 | |
| 				goto out;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		ilits->dbf_in = ilits->dbf_a;
 | |
| 		ilits->dbf_out = ilits->dbf_b;
 | |
| 		ilits->dbf_in_idx = 0;
 | |
| 		ilits->dbf_out_idx = 0;
 | |
| 		ilits->ppb = ON;
 | |
| 
 | |
| 		return 0;
 | |
| 	}
 | |
| 
 | |
| out:
 | |
| 	ilits->dlnp = DISABLE;
 | |
| 	/* free ping pong buffer */
 | |
| 	if (!ERR_ALLOC_MEM(ilits->dbf_a)) {
 | |
| 		for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 			ilits->dbf_a[i].mark = false;
 | |
| 			ipio_kfree((void **)&ilits->dbf_a[i].data);
 | |
| 		}
 | |
| 	}
 | |
| 	ipio_kfree((void **)&ilits->dbf_a);
 | |
| 
 | |
| 	if (!ERR_ALLOC_MEM(ilits->dbf_b)) {
 | |
| 		for (i = 0; i < TR_BUF_LIST_SIZE; i++) {
 | |
| 			ilits->dbf_b[i].mark = false;
 | |
| 			ipio_kfree((void **)&ilits->dbf_b[i].data);
 | |
| 		}
 | |
| 	}
 | |
| 	ipio_kfree((void **)&ilits->dbf_b);
 | |
| 
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static int debug_mode_get_data(struct file_buffer *file, u8 type, u32 frame_count)
 | |
| {
 | |
| 	int ret = 0, cdc_starIdx = 0;
 | |
| 	u8 cmd[2] = { 0 }, row, col;
 | |
| 	s16 temp;
 | |
| 	unsigned char *ptr;
 | |
| 	int j;
 | |
| 	u16 write_index = 0;
 | |
| 
 | |
| 	ilitek_debug_node_buff_control(DISABLE);
 | |
| 
 | |
| 	ilits->dbf = 0;
 | |
| 	row = ilits->ych_num;
 | |
| 	col = ilits->xch_num;
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	if (ilits->rib.nReportResolutionMode == POSITION_LOW_RESOLUTION) {
 | |
| 		cdc_starIdx = P5_X_DEBUG_LOW_RESOLUTION_FINGER_DATA_LENGTH;
 | |
| 	} else if (ilits->rib.nReportResolutionMode == POSITION_HIGH_RESOLUTION) {
 | |
| 		cdc_starIdx = P5_X_DEBUG_HIGH_RESOLUTION_FINGER_DATA_LENGTH;
 | |
| 	}
 | |
| 
 | |
| 	if (ilits->chip->core_ver < CORE_VER_1700) {
 | |
| 		cmd[0] = 0xFA;
 | |
| 		cmd[1] = type;
 | |
| 		ret = ilits->wrapper(cmd, 2, NULL, 0, ON, OFF);
 | |
| 	}
 | |
| 
 | |
| 	if (ilitek_debug_node_buff_control(ENABLE) < 0) {
 | |
| 		ILI_ERR("Failed to allocate debug buf\n");
 | |
| 		ret = -ENOMEM;
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Write 0xFA,0x%x failed\n", type);
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	while (write_index < frame_count) {
 | |
| 		file->wlen = 0;
 | |
| 		ILI_INFO("frame = %d,index = %d,count = %d\n", write_index, ilits->odi, ilits->dbf);
 | |
| 		if (!wait_event_interruptible_timeout(ilits->inq, ilits->dbl[ilits->odi].mark, msecs_to_jiffies(3000))) {
 | |
| 			ILI_ERR("debug mode get data timeout!\n");
 | |
| 			goto out;
 | |
| 		}
 | |
| 
 | |
| 		mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 		memset(file->ptr, 0, file->max_size);
 | |
| 		file->wlen += snprintf(file->ptr + file->wlen, (file->max_size - file->wlen), "\n\nFrame%d,", write_index);
 | |
| 		for (j = 0; j < col; j++)
 | |
| 			file->wlen += snprintf(file->ptr + file->wlen, (file->max_size - file->wlen), "[X%d] ,", j);
 | |
| 		ptr = &ilits->dbl[ilits->odi].data[cdc_starIdx];
 | |
| 		for (j = 0; j < row * col; j++, ptr += 2) {
 | |
| 			temp = (*ptr << 8) + *(ptr + 1);
 | |
| 			if (j % col == 0)
 | |
| 				file->wlen += snprintf(file->ptr + file->wlen, (file->max_size - file->wlen), "\n[Y%d] ,", (j / col));
 | |
| 			file->wlen += snprintf(file->ptr + file->wlen, (file->max_size - file->wlen), "%d, ", temp);
 | |
| 		}
 | |
| 		file->wlen += snprintf(file->ptr + file->wlen, (file->max_size - file->wlen), "\n[X] ,");
 | |
| 		for (j = 0; j < row + col; j++, ptr += 2) {
 | |
| 			temp = (*ptr << 8) + *(ptr + 1);
 | |
| 			if (j == col)
 | |
| 				file->wlen += snprintf(file->ptr + file->wlen, (file->max_size - file->wlen), "\n[Y] ,");
 | |
| 			file->wlen += snprintf(file->ptr + file->wlen, (file->max_size - file->wlen), "%d, ", temp);
 | |
| 		}
 | |
| 		file_write(file, false);
 | |
| 		write_index++;
 | |
| 
 | |
| 		mutex_unlock(&ilits->touch_mutex);
 | |
| 
 | |
| 		ilits->dbl[ilits->odi].mark = false;
 | |
| 		ilits->odi = ((ilits->odi + 1) % TR_BUF_LIST_SIZE);
 | |
| 	}
 | |
| out:
 | |
| 	ilitek_debug_node_buff_control(DISABLE);
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static int dev_mkdir(char *name, umode_t mode)
 | |
| {
 | |
| 	int err = 0;
 | |
| #if LINUX_VERSION_CODE <= KERNEL_VERSION(4, 14, 0)
 | |
| 	mm_segment_t fs;
 | |
| 
 | |
| 	ILI_INFO("mkdir: %s\n", name);
 | |
| 	fs = get_fs();
 | |
| 	set_fs(KERNEL_DS);
 | |
| #ifdef CONFIG_ARCH_HAS_SYSCALL_WRAPPER
 | |
| 	err = ksys_mkdir(name, mode);
 | |
| #else
 | |
| 	err = sys_mkdir(name, mode);
 | |
| #endif
 | |
| 	set_fs(fs);
 | |
| #else
 | |
| 	err = -1;
 | |
| #endif
 | |
| 	return err;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_get_delta_data_read(struct file *pFile, char __user *buf, size_t size, loff_t *pos)
 | |
| {
 | |
| 	s16 *delta = NULL;
 | |
| 	int row = 0, col = 0,  index = 0;
 | |
| 	int ret, i, x, y;
 | |
| 	int read_length = 0, len = 0;
 | |
| 	u8 cmd[2] = {0};
 | |
| 	u8 *data = NULL;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 	ili_wq_ctrl(WQ_BAT, DISABLE);
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	row = ilits->ych_num;
 | |
| 	col = ilits->xch_num;
 | |
| 	read_length = 4 + 2 * row * col + 1 ;
 | |
| 
 | |
| 	ILI_INFO("read length = %d\n", read_length);
 | |
| 
 | |
| 	data = kcalloc(read_length + 1, sizeof(u8), GFP_KERNEL);
 | |
| 	if (ERR_ALLOC_MEM(data)) {
 | |
| 		ILI_ERR("Failed to allocate data mem\n");
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	delta = kcalloc(P5_X_DEBUG_MODE_PACKET_LENGTH, sizeof(s32), GFP_KERNEL);
 | |
| 	if (ERR_ALLOC_MEM(delta)) {
 | |
| 		ILI_ERR("Failed to allocate delta mem\n");
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	cmd[0] = 0xB7;
 | |
| 	cmd[1] = 0x1; /* get delta */
 | |
| 	ret = ilits->wrapper(cmd, sizeof(cmd), NULL, 0, OFF, OFF);
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Failed to write 0xB7,0x1 command, %d\n", ret);
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	msleep(120);
 | |
| 
 | |
| 	/* read debug packet header */
 | |
| 	ret = ilits->wrapper(NULL, 0, data, read_length, OFF, OFF);
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Read debug packet header failed, %d\n", ret);
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	cmd[1] = 0x03; /* switch to normal mode */
 | |
| 	ret = ilits->wrapper(cmd, sizeof(cmd), NULL, 0, ON, OFF);
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Failed to write 0xB7,0x3 command, %d\n", ret);
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	for (i = 4, index = 0; i < row * col * 2 + 4; i += 2, index++)
 | |
| 		delta[index] = (data[i] << 8) + data[i + 1];
 | |
| 
 | |
| 	len = snprintf(g_user_buf, PAGE_SIZE - len, "======== Deltadata ========\n");
 | |
| 	ILI_INFO("======== Deltadata ========\n");
 | |
| 
 | |
| 	len += snprintf(g_user_buf + len, PAGE_SIZE - len,
 | |
| 		"Header 0x%x ,Type %d, Length %d\n", data[0], data[1], (data[2] << 8) | data[3]);
 | |
| 	ILI_INFO("Header 0x%x ,Type %d, Length %d\n", data[0], data[1], (data[2] << 8) | data[3]);
 | |
| 
 | |
| 	/* print delta data */
 | |
| 	for (y = 0; y < row; y++) {
 | |
| 		len += snprintf(g_user_buf + len, PAGE_SIZE - len, "[%2d] ", (y+1));
 | |
| 		ILI_INFO("[%2d] ", (y+1));
 | |
| 
 | |
| 		for (x = 0; x < col; x++) {
 | |
| 			int shift = y * col + x;
 | |
| 			len += snprintf(g_user_buf + len, PAGE_SIZE - len, "%5d", delta[shift]);
 | |
| 			printk(KERN_CONT "%5d", delta[shift]);
 | |
| 		}
 | |
| 		len += snprintf(g_user_buf + len, PAGE_SIZE - len, "\n");
 | |
| 		printk(KERN_CONT "\n");
 | |
| 	}
 | |
| 
 | |
| 	if (copy_to_user(buf, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	*pos += len;
 | |
| 
 | |
| out:
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	ili_wq_ctrl(WQ_BAT, ENABLE);
 | |
| 	ipio_kfree((void **)&data);
 | |
| 	ipio_kfree((void **)&delta);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_fw_get_raw_data_read(struct file *pFile, char __user *buf, size_t size, loff_t *pos)
 | |
| {
 | |
| 	s16 *rawdata = NULL;
 | |
| 	int row = 0, col = 0,  index = 0;
 | |
| 	int ret, i, x, y;
 | |
| 	int read_length = 0, len = 0;
 | |
| 	u8 cmd[2] = {0};
 | |
| 	u8 *data = NULL;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 	ili_wq_ctrl(WQ_BAT, DISABLE);
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	row = ilits->ych_num;
 | |
| 	col = ilits->xch_num;
 | |
| 	read_length = 4 + 2 * row * col + 1 ;
 | |
| 
 | |
| 	ILI_INFO("read length = %d\n", read_length);
 | |
| 
 | |
| 	data = kcalloc(read_length + 1, sizeof(u8), GFP_KERNEL);
 | |
| 	if (ERR_ALLOC_MEM(data)) {
 | |
| 		ILI_ERR("Failed to allocate data mem\n");
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	rawdata = kcalloc(P5_X_DEBUG_MODE_PACKET_LENGTH, sizeof(s32), GFP_KERNEL);
 | |
| 	if (ERR_ALLOC_MEM(rawdata)) {
 | |
| 		ILI_ERR("Failed to allocate rawdata mem\n");
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	cmd[0] = 0xB7;
 | |
| 	cmd[1] = 0x2; /* get rawdata */
 | |
| 	ret = ilits->wrapper(cmd, sizeof(cmd), NULL, 0, OFF, OFF);
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Failed to write 0xB7,0x2 command, %d\n", ret);
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	msleep(120);
 | |
| 
 | |
| 	/* read debug packet header */
 | |
| 	ret = ilits->wrapper(NULL, 0, data, read_length, OFF, OFF);
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Read debug packet header failed, %d\n", ret);
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	cmd[1] = 0x03; /* switch to normal mode */
 | |
| 	ret = ilits->wrapper(cmd, sizeof(cmd), NULL, 0, ON, OFF);
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Failed to write 0xB7,0x3 command, %d\n", ret);
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	for (i = 4, index = 0; i < row * col * 2 + 4; i += 2, index++)
 | |
| 		rawdata[index] = (data[i] << 8) + data[i + 1];
 | |
| 
 | |
| 	len = snprintf(g_user_buf, PAGE_SIZE, "======== RawData ========\n");
 | |
| 	ILI_INFO("======== RawData ========\n");
 | |
| 
 | |
| 	len += snprintf(g_user_buf + len, PAGE_SIZE - len,
 | |
| 			"Header 0x%x ,Type %d, Length %d\n", data[0], data[1], (data[2] << 8) | data[3]);
 | |
| 	ILI_INFO("Header 0x%x ,Type %d, Length %d\n", data[0], data[1], (data[2] << 8) | data[3]);
 | |
| 
 | |
| 	/* print raw data */
 | |
| 	for (y = 0; y < row; y++) {
 | |
| 		len += snprintf(g_user_buf + len, PAGE_SIZE - len, "[%2d] ", (y+1));
 | |
| 		ILI_INFO("[%2d] ", (y+1));
 | |
| 
 | |
| 		for (x = 0; x < col; x++) {
 | |
| 			int shift = y * col + x;
 | |
| 			len += snprintf(g_user_buf + len, PAGE_SIZE - len, "%5d", rawdata[shift]);
 | |
| 			printk(KERN_CONT "%5d", rawdata[shift]);
 | |
| 		}
 | |
| 		len += snprintf(g_user_buf + len, PAGE_SIZE - len, "\n");
 | |
| 		printk(KERN_CONT "\n");
 | |
| 	}
 | |
| 
 | |
| 	if (copy_to_user(buf, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	*pos += len;
 | |
| 
 | |
| out:
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	ili_wq_ctrl(WQ_BAT, ENABLE);
 | |
| 	ipio_kfree((void **)&data);
 | |
| 	ipio_kfree((void **)&rawdata);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_fw_pc_counter_read(struct file *pFile, char __user *buf, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int len = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	ili_ic_get_pc_counter(0);
 | |
| 	len = snprintf(g_user_buf, PAGE_SIZE, "pc = 0x%x, latch = 0x%x\n", ilits->fw_pc, ilits->fw_latch);
 | |
| 
 | |
| 	if (copy_to_user(buf, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	*pos += len;
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| int ili_cascade_rw_tp_reg(u32 mcu, u32 type, u32 addr, u32 wdata, u32 wlen, u32 *rdata)
 | |
| {
 | |
| 	int len = 0;
 | |
| #if (TDDI_INTERFACE == BUS_SPI)
 | |
| 	int ret = 0;
 | |
| 	bool mcu_on = ON, read = 0;
 | |
| 	u32 read_data;
 | |
| 
 | |
| 	if (ilits->slave_wr_ctrl == SLAVE) {
 | |
| 		ilits->ice_mode_ctrl(ENABLE, mcu, BOTH);
 | |
| 	} else {
 | |
| 		ret = ili_ice_mode_ctrl_by_mode(ENABLE, (mcu == mcu_on) ? ON : OFF, MASTER);
 | |
| 		if (ret < 0) {
 | |
| 			ILI_ERR("Failed to enter ICE mode, ret = %d\n", ret);
 | |
| 			len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to enter ICE mode");
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if (type == read) {
 | |
| 		ili_spi_ice_mode_read(addr, &read_data, sizeof(u32), ilits->slave_wr_ctrl);
 | |
| 		*rdata = read_data;
 | |
| 		ILI_INFO("[READ]:addr = 0x%06x, read = 0x%08x\n", addr, read_data);
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "READ:addr = 0x%06x, read = 0x%08x\n", addr, read_data);
 | |
| 	} else {
 | |
| 		if (ilits->slave_wr_ctrl == SLAVE) {
 | |
| #if !ENABLE_SPICASCADE_V2
 | |
| 			ili_mspi_write_slave_register(addr, wdata, wlen);
 | |
| #endif
 | |
| 		} else {
 | |
| 			if (ili_ice_mode_write_by_mode(addr, wdata, wlen, MASTER) < 0) {
 | |
| 				len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Write data error");
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		ILI_INFO("[WRITE]:addr = 0x%06x, write = 0x%08x, len = %d byte\n", addr, wdata, wlen);
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "WRITE:addr = 0x%06x, write = 0x%08x, len =%d byte\n", addr, wdata, wlen);
 | |
| 	}
 | |
| 
 | |
| 	if (ilits->slave_wr_ctrl == SLAVE)
 | |
| 		ilits->ice_mode_ctrl(DISABLE, mcu, BOTH);
 | |
| 	else
 | |
| 		ret = ili_ice_mode_ctrl(DISABLE, (mcu == mcu_on) ? ON : OFF );
 | |
| 
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Failed to disable ICE mode, ret = %d\n", ret);
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to disable ICE mode");
 | |
| 	}
 | |
| #endif
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| #if ENABLE_SPICASCADE_V2
 | |
| int ili_cascade_rw_tp_reg_v2(u32 mcu, u32 type, u32 addr, u32 wdata, u32 wlen, u32 *rdata)
 | |
| {
 | |
| 	int len = 0;
 | |
| 	ILI_DBG("type = %d, slave_wr_ctrl = %d\n", type, ilits->slave_wr_ctrl);
 | |
| 	if (type == ILI_WRITE && ilits->slave_wr_ctrl == SLAVE) {
 | |
| 		ili_ice_slave_write_register(addr, wdata, wlen);
 | |
| 		ILI_INFO("[WRITE]:addr = 0x%06x, write = 0x%08x, len = %d byte\n", addr, wdata, wlen);
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "WRITE:addr = 0x%06x, write = 0x%08x, len =%d byte\n", addr, wdata, wlen);
 | |
| 	} else {
 | |
| 		len = ili_cascade_rw_tp_reg(mcu, type, addr, wdata, wlen, rdata);
 | |
| 	}
 | |
| 
 | |
| 	return len;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| static u32 rw_reg[6] = {0};
 | |
| static ssize_t ilitek_proc_rw_tp_reg_read(struct file *pFile, char __user *buf, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int ret = 0, len = 0;
 | |
| 	bool mcu_on = 0, read = 0;
 | |
| 	u32 type, addr, read_data, write_data, write_len, stop_mcu;
 | |
| 	bool esd_en = ilits->wq_esd_ctrl, bat_en = ilits->wq_bat_ctrl;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	stop_mcu = rw_reg[0];
 | |
| 	type = rw_reg[1];
 | |
| 	addr = rw_reg[2];
 | |
| 	write_data = rw_reg[3];
 | |
| 	write_len = rw_reg[4];
 | |
| 
 | |
| 	ILI_INFO("stop_mcu = %d\n", rw_reg[0]);
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, DISABLE);
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
|     if (ilits->cascade_info_block.nNum != 0) {
 | |
| #if (TDDI_INTERFACE == BUS_SPI)
 | |
| #if ENABLE_SPICASCADE_V2
 | |
| 		len = ili_cascade_rw_tp_reg_v2(stop_mcu, type, addr, write_data, write_len, &read_data);
 | |
| #else
 | |
| 		len = ili_cascade_rw_tp_reg(stop_mcu, type, addr, write_data, write_len, &read_data);
 | |
| #endif
 | |
| #elif (TDDI_INTERFACE == BUS_I2C)
 | |
| 		if (stop_mcu == mcu_on)
 | |
| 			ret = ili_ice_mode_ctrl_by_mode(ENABLE, ON, ilits->slave_wr_ctrl);
 | |
| 		else
 | |
| 			ret = ili_ice_mode_ctrl_by_mode(ENABLE, OFF, ilits->slave_wr_ctrl);
 | |
| 
 | |
| 		if (ret < 0) {
 | |
| 			len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to enter ICE mode");
 | |
| 		}
 | |
| 
 | |
| 		if (type == read) {
 | |
| 			if (ili_ice_mode_read_by_mode(addr, &read_data, sizeof(u32), ilits->slave_wr_ctrl) < 0) {
 | |
| 				len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Read data error");
 | |
| 			}
 | |
| 
 | |
| 			len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "READ:addr = 0x%06x, read = 0x%08x\n", addr, read_data);
 | |
| 		} else {
 | |
| 			if (ili_ice_mode_write_by_mode(addr, write_data, write_len, ilits->slave_wr_ctrl) < 0) {
 | |
| 				len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Write data error");
 | |
| 			}
 | |
| 
 | |
| 			ILI_INFO("[WRITE]:addr = 0x%06x, write = 0x%08x, len = %d byte\n", addr, write_data, write_len);
 | |
| 			len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "WRITE:addr = 0x%06x, write = 0x%08x, len =%d byte\n", addr, write_data, write_len);
 | |
| 		}
 | |
| 
 | |
| 		if (stop_mcu == mcu_on)
 | |
| 			ret = ili_ice_mode_ctrl_by_mode(DISABLE, ON, ilits->slave_wr_ctrl);
 | |
| 		else
 | |
| 			ret = ili_ice_mode_ctrl_by_mode(DISABLE, OFF, ilits->slave_wr_ctrl);
 | |
| 
 | |
| 		if (ret < 0) {
 | |
| 			len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to disable ICE mode");
 | |
| 		}
 | |
| #endif
 | |
|     } else {
 | |
|         if (stop_mcu == mcu_on)
 | |
|             ret = ili_ice_mode_ctrl(ENABLE, ON);
 | |
|         else
 | |
|             ret = ili_ice_mode_ctrl(ENABLE, OFF);
 | |
| 
 | |
|         if (ret < 0) {
 | |
|             ILI_ERR("Failed to enter ICE mode, ret = %d\n", ret);
 | |
|             len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to enter ICE mode");
 | |
|         }
 | |
| 
 | |
|         if (type == read) {
 | |
|             if (ili_ice_mode_read(addr, &read_data, sizeof(u32)) < 0) {
 | |
|                 ILI_ERR("Read data error\n");
 | |
|                 len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Read data error");
 | |
|             }
 | |
| 
 | |
|             ILI_INFO("[READ]:addr = 0x%06x, read = 0x%08x\n", addr, read_data);
 | |
|             len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "READ:addr = 0x%06x, read = 0x%08x\n", addr, read_data);
 | |
|         } else {
 | |
|             if (ili_ice_mode_write(addr, write_data, write_len) < 0) {
 | |
|                 ILI_ERR("Write data error\n");
 | |
|                 len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Write data error");
 | |
|             }
 | |
| 
 | |
|             ILI_INFO("[WRITE]:addr = 0x%06x, write = 0x%08x, len = %d byte\n", addr, write_data, write_len);
 | |
|             len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "WRITE:addr = 0x%06x, write = 0x%08x, len =%d byte\n", addr, write_data, write_len);
 | |
|         }
 | |
| 
 | |
|         if (stop_mcu == mcu_on)
 | |
|             ret = ili_ice_mode_ctrl(DISABLE, ON);
 | |
|         else
 | |
|             ret = ili_ice_mode_ctrl(DISABLE, OFF);
 | |
| 
 | |
|         if (ret < 0) {
 | |
|             ILI_ERR("Failed to disable ICE mode, ret = %d\n", ret);
 | |
|             len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to disable ICE mode");
 | |
|         }
 | |
|     }
 | |
| 
 | |
| 	if (copy_to_user((char *)buf, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, ENABLE);
 | |
| 
 | |
| 	*pos += len;
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_rw_tp_reg_write(struct file *filp, const char *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	char *token = NULL, *cur = NULL;
 | |
| 	char cmd[256] = { 0 };
 | |
| 	u32 count = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if ((size - 1) > sizeof(cmd)) {
 | |
| 		ILI_ERR("ERROR! input length is larger than local buffer\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	if (buff != NULL) {
 | |
| 		if (copy_from_user(cmd, buff, size - 1)) {
 | |
| 			ILI_INFO("Failed to copy data from user space\n");
 | |
| 			size = -1;
 | |
| 			goto out;
 | |
| 		}
 | |
| 	}
 | |
| 	token = cur = cmd;
 | |
| 	while ((token = strsep(&cur, ",")) != NULL) {
 | |
| 		if (count >= (sizeof(rw_reg) / sizeof(u32))) {
 | |
| 			ILI_ERR("command length is larger than function need\n");
 | |
| 			break;
 | |
| 		}
 | |
| 		rw_reg[count] = ili_str2hex(token);
 | |
| 		ILI_INFO("rw_reg[%d] = 0x%x\n", count, rw_reg[count]);
 | |
| 		count++;
 | |
| 	}
 | |
| 
 | |
| out:
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| static u8 fw_cmd_buff[256] = { 0 };
 | |
| static ssize_t ilitek_proc_fw_cmd_read(struct file *pFile, char __user *buf, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int len = 0, i = 0;
 | |
| 	u8 *wrap_rbuf = NULL;
 | |
| 	u16 wrap_wlen = 0, wrap_rlen = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	wrap_rlen = (fw_cmd_buff[0] << 8) | fw_cmd_buff[1];
 | |
| 	wrap_wlen = (fw_cmd_buff[2] << 8) | fw_cmd_buff[3];
 | |
| 
 | |
| 	ILI_INFO("fw_cmd read wrap_wlen = %d, wrap_rlen = %d\n", wrap_wlen, wrap_rlen);
 | |
| 
 | |
| 	if (wrap_wlen > IOCTL_I2C_BUFF || wrap_rlen > IOCTL_I2C_BUFF) {
 | |
| 		ILI_ERR("ERROR! R/W len is largn than ioctl buf\n");
 | |
| 		return -ENOTTY;
 | |
| 	}
 | |
| 
 | |
| 	if (wrap_rlen > 0) {
 | |
| 		wrap_rbuf = kcalloc(IOCTL_I2C_BUFF, sizeof(u8), GFP_KERNEL);
 | |
| 		if (ERR_ALLOC_MEM(wrap_rbuf)) {
 | |
| 			ILI_ERR("Failed to allocate mem\n");
 | |
| 			return -ENOMEM;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if (atomic_read(&ilits->ice_stat)) {
 | |
| 		ilits->wrapper(fw_cmd_buff + 4, wrap_wlen, wrap_rbuf, wrap_rlen, OFF, OFF);
 | |
| 	} else {
 | |
| 		if (ilits->actual_tp_mode == P5_X_FW_TEST_MODE) {
 | |
| 			ilits->wrapper(fw_cmd_buff + 4, wrap_wlen, wrap_rbuf, wrap_rlen, ON, ON);
 | |
| 		} else {
 | |
| 			ilits->wrapper(fw_cmd_buff + 4, wrap_wlen, wrap_rbuf, wrap_rlen, ON, OFF);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	ili_dump_data(fw_cmd_buff + 4, 8, wrap_wlen, 16, "write fw data:");
 | |
| 
 | |
| 	if (wrap_rlen > 0) {
 | |
| 		ili_dump_data(wrap_rbuf, 8, wrap_rlen, 16, "read fw data:");
 | |
| 		for (i = 0; i < wrap_rlen; i++) {
 | |
| 			len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%02X", wrap_rbuf[i]);
 | |
| 		}
 | |
| 	} else {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "Ack");
 | |
| 	}
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "\n");
 | |
| 
 | |
| 	if (copy_to_user((char *)buf, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	*pos += len;
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_fw_cmd_write(struct file *filp, const char *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	char *token = NULL, *cur = NULL;
 | |
| 	char cmd[256] = { 0 };
 | |
| 	u32 count = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if ((size - 1) > sizeof(cmd)) {
 | |
| 		ILI_ERR("ERROR! input length is larger than local buffer\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	if (buff != NULL) {
 | |
| 		if (copy_from_user(cmd, buff, size - 1)) {
 | |
| 			ILI_INFO("Failed to copy data from user space\n");
 | |
| 			size = -1;
 | |
| 			goto out;
 | |
| 		}
 | |
| 	}
 | |
| 	token = cur = cmd;
 | |
| 	while ((token = strsep(&cur, ",")) != NULL) {
 | |
| 		if (count >= sizeof(fw_cmd_buff)) {
 | |
| 			ILI_ERR("command length is larger than function need\n");
 | |
| 			break;
 | |
| 		}
 | |
| 		fw_cmd_buff[count] = ili_str2hex(token);
 | |
| 		ILI_INFO("fw_cmd write buff[%d] = 0x%x\n", count, fw_cmd_buff[count]);
 | |
| 		count++;
 | |
| 	}
 | |
| 
 | |
| out:
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_debug_switch_read(struct file *pFile, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	bool open;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	mutex_lock(&ilits->debug_read_mutex);
 | |
| 	mutex_lock(&ilits->debug_mutex);
 | |
| 
 | |
| 	open = !ilits->dnp;
 | |
| 	ilits->all_frame_full = false;
 | |
| 
 | |
| 	ilitek_debug_node_buff_control(open);
 | |
| 
 | |
| 	size = snprintf(g_user_buf, USER_STR_BUFF * sizeof(unsigned char), "dnp : %s\n", ilits->dnp ? "Enabled" : "Disabled");
 | |
| 	*pos = size;
 | |
| 
 | |
| 	if (copy_to_user(buff, g_user_buf, size))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	mutex_unlock(&ilits->debug_mutex);
 | |
| 	mutex_unlock(&ilits->debug_read_mutex);
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_debug_all_switch_read(struct file *pFile, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	bool open;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	mutex_lock(&ilits->debug_read_mutex);
 | |
| 	mutex_lock(&ilits->debug_mutex);
 | |
| 
 | |
| 	open = !ilits->dlnp;
 | |
| 
 | |
| 	ilitek_debug_all_node_buff_control(open);
 | |
| 
 | |
| 	size = snprintf(g_user_buf, USER_STR_BUFF * sizeof(unsigned char), "dlnp : %s\n", ilits->dlnp ? "Enabled" : "Disabled");
 | |
| 	*pos = size;
 | |
| 
 | |
| 	if (copy_to_user(buff, g_user_buf, size))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	mutex_unlock(&ilits->debug_mutex);
 | |
| 	mutex_unlock(&ilits->debug_read_mutex);
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| static void ilitek_switch_debug_message_ping_pong_buff(void)
 | |
| {
 | |
| 	bool flag;
 | |
| 	int temp;
 | |
| 	ILI_DBG("switch debug_message buff\n");
 | |
| 	mutex_lock(&ilits->debug_mutex);
 | |
| 
 | |
| 	flag = !ilits->ppb;
 | |
| 
 | |
| 	ILI_DBG("Before dbf_in_idx=%d, dbf_out_idx=%d\n", ilits->dbf_in_idx, ilits->dbf_out_idx);
 | |
| 	if (flag) {
 | |
| 		ILI_INFO("debug_message buff, input set a, output set b\n");
 | |
| 		ilits->dbf_in = ilits->dbf_a;
 | |
| 		ilits->dbf_out = ilits->dbf_b;
 | |
| 	} else {
 | |
| 		ILI_INFO("debug_message buff, input set b, output set a\n");
 | |
| 		ilits->dbf_in = ilits->dbf_b;
 | |
| 		ilits->dbf_out = ilits->dbf_a;
 | |
| 	}
 | |
| 	temp = ilits->dbf_in_idx;
 | |
| 	ilits->dbf_in_idx = ilits->dbf_out_idx;
 | |
| 	ilits->dbf_out_idx = temp;
 | |
| 
 | |
| 	ilits->ppb = flag;
 | |
| 
 | |
| 	ILI_DBG("dbf_in_idx=%d, dbf_out_idx=%d, ilits->ppb=%d\n", ilits->dbf_in_idx, ilits->dbf_out_idx, ilits->ppb);
 | |
| 
 | |
| 	mutex_unlock(&ilits->debug_mutex);
 | |
| }
 | |
| 
 | |
| static int ilitek_proc_debug_all_message_show(struct seq_file *m, void *v)
 | |
| {
 | |
| 	int i = 0, count = 0;
 | |
| 	int data_count = 0;
 | |
| 	int one_data_bytes = 0;
 | |
| 	int need_read_data_len = 0;
 | |
| 	int type = 0;
 | |
| 
 | |
| 	if (m->size < 500 * K) {
 | |
| 		m->count = m->size;
 | |
| 		return 0;
 | |
| 	}
 | |
| 
 | |
| 	if (!ilits->dlnp) {
 | |
| 		ILI_ERR("Debug flag isn't enabled (%d)\n", ilits->dlnp);
 | |
| 		seq_printf(m, "Debug flag isn't enabled (%d)\n", ilits->dlnp);
 | |
| 		return -EAGAIN;
 | |
| 	}
 | |
| 	ilitek_switch_debug_message_ping_pong_buff();
 | |
| 
 | |
| 	count = 0;
 | |
| 	do {
 | |
| 		if (ilits->dbf_out[count].mark) {
 | |
| 			if (ilits->dbf_out[count].data[0] == P5_X_DEMO_PACKET_ID) {
 | |
| 				need_read_data_len = P5_X_DEMO_MODE_PACKET_LEN;
 | |
| 			} else if (ilits->dbf_out[count].data[0] == P5_X_I2CUART_PACKET_ID) {
 | |
| 				type = ilits->dbf_out[count].data[3] & 0x0F;
 | |
| 
 | |
| 				data_count = ilits->dbf_out[count].data[1] * ilits->dbf_out[count].data[2];
 | |
| 
 | |
| 				if (type == 0 || type == 1 || type == 6) {
 | |
| 					one_data_bytes = 1;
 | |
| 				} else if (type == 2 || type == 3) {
 | |
| 					one_data_bytes = 2;
 | |
| 				} else if (type == 4 || type == 5) {
 | |
| 					one_data_bytes = 4;
 | |
| 				}
 | |
| 				need_read_data_len = data_count * one_data_bytes + 1 + 5;
 | |
| 			} else if (ilits->dbf_out[count].data[0] == P5_X_DEBUG_PACKET_ID					/* A7 */
 | |
| 					|| ilits->dbf_out[count].data[0] == P5_X_DEBUG_HIGH_RESOLUTION_PACKET_ID	/* A8 */
 | |
| 					|| ilits->dbf_out[count].data[0] == P5_X_DEMO_HIGH_RESOLUTION_PACKET_ID		/* 5B */
 | |
| 					|| ilits->dbf_out[count].data[0] == P5_X_DEBUG_LITE_PACKET_ID) {			/* 9A */
 | |
| 				need_read_data_len = (int) ((ilits->dbf_out[count].data[1] << 8) + ilits->dbf_out[count].data[2]) & 0xFFFF;
 | |
| 			}
 | |
| 			if (ilits->pen_info.pen_data_mode == PEN_ONLY_SIGNAL_MODE
 | |
| 				|| ilits->pen_info.pen_data_mode == PEN_ONLY_RAW_DATA_MODE) {
 | |
| 				seq_printf(m, ":0x80,");
 | |
| 			} else if (ilits->pen_info.pen_data_mode == HAND_ONLY_SIGNAL_MODE
 | |
| 				|| ilits->pen_info.pen_data_mode == HAND_ONLY_RAW_DATA_MODE) {
 | |
| 				seq_printf(m, ":0x81,");
 | |
| 			} else if (ilits->tp_data_format == DATA_FORMAT_DEMO) {
 | |
| 				seq_printf(m, ":0x10,");
 | |
| 			} else if(ilits->tp_data_format == DATA_FORMAT_DEBUG) {
 | |
| 				seq_printf(m, ":0x45,");
 | |
| 			}
 | |
| 
 | |
| 			for (i = 0; i < need_read_data_len; i++) {
 | |
| 				seq_printf(m, "%02X", ilits->dbf_out[count].data[i]);
 | |
| 			}
 | |
| 			seq_printf(m, ":\n");
 | |
| 			ilits->dbf_out[count].mark = false;
 | |
| 		}
 | |
| 		count++;
 | |
| 
 | |
| 	} while (count < ilits->dbf_out_idx);
 | |
| 
 | |
| 	ILI_DBG("total send %d frame\n", ilits->dbf_out_idx);
 | |
| 
 | |
| 	ilits->dbf_out_idx = 0;
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| #if DMESG_SEQ_FILE
 | |
| static int ilitek_proc_debug_message_show(struct seq_file *m, void *v)
 | |
| {
 | |
| 	int i = 0;
 | |
| 	int data_count = 0;
 | |
| 	int one_data_bytes = 0;
 | |
| 	int need_read_data_len = 0;
 | |
| 	int type = 0;
 | |
| 
 | |
| 	/* '0' ~ 'F' mapping table */
 | |
| 	char charmapping[16] = {0x30, 0x31, 0x32, 0x33, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39, 0x41, 0x42, 0x43, 0x44, 0x45, 0x46 };
 | |
| 
 | |
| 	if (m->size < 16 * K) {
 | |
| 		m->count = m->size;
 | |
| 		return 0;
 | |
| 	}
 | |
| 
 | |
| 	if (!ilits->dnp) {
 | |
| 		ILI_ERR("Debug flag isn't enabled (%d)\n", ilits->dnp);
 | |
| 		seq_printf(m, "Debug flag isn't enabled (%d)\n", ilits->dnp);
 | |
| 		return -EAGAIN;
 | |
| 	}
 | |
| 
 | |
| 	if (ilits->odi == ilits->dbf && ilits->all_frame_full == false) {
 | |
| 		/* ILI_DBG("WARNING ! there's no cdc data.\n"); */
 | |
| 		return -EAGAIN;
 | |
| 	}
 | |
| 
 | |
| 	mutex_lock(&ilits->debug_read_mutex);
 | |
| 	ILI_DBG("f_count= %d, index = %d, mark = %d\n", ilits->dbf, ilits->odi, ilits->dbl[ilits->odi].mark);
 | |
| 	if (!wait_event_interruptible_timeout(ilits->inq, ilits->dbl[ilits->odi].mark, msecs_to_jiffies(ilits->wait_int_timeout))) {
 | |
| 		ILI_ERR("WARNING ! there's no data received.\n");
 | |
| 		mutex_unlock(&ilits->debug_read_mutex);
 | |
| 		return -EAGAIN;
 | |
| 	}
 | |
| 	mutex_lock(&ilits->debug_mutex);
 | |
| 
 | |
| 	ILI_DBG("dbl mark = %d, data[0] = 0x%X, data[1] = 0x%X, data[2] = 0x%X \n", ilits->dbl[ilits->odi].mark, ilits->dbl[ilits->odi].data[0], ilits->dbl[ilits->odi].data[1], ilits->dbl[ilits->odi].data[2]);
 | |
| 
 | |
| 	if (ilits->dbl[ilits->odi].mark) {
 | |
| 		if (ilits->dbl[ilits->odi].data[0] == P5_X_DEMO_PACKET_ID) {
 | |
| 			need_read_data_len = P5_X_DEMO_MODE_PACKET_LEN;
 | |
| 		} else if (ilits->dbl[ilits->odi].data[0] == P5_X_I2CUART_PACKET_ID) {
 | |
| 			type = ilits->dbl[ilits->odi].data[3] & 0x0F;
 | |
| 
 | |
| 			data_count = ilits->dbl[ilits->odi].data[1] * ilits->dbl[ilits->odi].data[2];
 | |
| 
 | |
| 			if (type == 0 || type == 1 || type == 6) {
 | |
| 				one_data_bytes = 1;
 | |
| 			} else if (type == 2 || type == 3) {
 | |
| 				one_data_bytes = 2;
 | |
| 			} else if (type == 4 || type == 5) {
 | |
| 				one_data_bytes = 4;
 | |
| 			}
 | |
| 			need_read_data_len = data_count * one_data_bytes + 1 + 5;
 | |
| 		} else if (ilits->dbl[ilits->odi].data[0] == P5_X_DEBUG_PACKET_ID					/* A7 */
 | |
| 				|| ilits->dbl[ilits->odi].data[0] == P5_X_DEBUG_HIGH_RESOLUTION_PACKET_ID	/* A8 */
 | |
| 				|| ilits->dbl[ilits->odi].data[0] == P5_X_DEMO_HIGH_RESOLUTION_PACKET_ID	/* 5B */
 | |
| 				|| ilits->dbl[ilits->odi].data[0] == P5_X_DEBUG_LITE_PACKET_ID) {			/* 9A */
 | |
| 			need_read_data_len = (int) ((ilits->dbl[ilits->odi].data[1] << 8) + ilits->dbl[ilits->odi].data[2]) & 0xFFFF;
 | |
| 		}
 | |
| 
 | |
| 		ILI_DBG("Need Read data len = %d\n", need_read_data_len);
 | |
| 
 | |
| 		if (ilits->outputStrArr == NULL || ERR_ALLOC_MEM(ilits->outputStrArr)) {
 | |
| 			ILI_ERR("ilits->outputStrArr memory error.\n");
 | |
| 			ilits->outputStrArr = vmalloc(TR_BUF_SIZE * 2);
 | |
| 		}
 | |
| 		memset(ilits->outputStrArr, 0, need_read_data_len * 2 + 4);
 | |
| 		for (i = 0; i < need_read_data_len * 2; i+=2) {
 | |
| 			ilits->outputStrArr[i] = charmapping[(ilits->dbl[ilits->odi].data[i >> 1]) >> 4];
 | |
| 			ilits->outputStrArr[i+1] = charmapping[(ilits->dbl[ilits->odi].data[i >> 1]) & 0x0F];
 | |
| 		}
 | |
| 		seq_printf(m, "%s", ilits->outputStrArr);
 | |
| 		seq_printf(m, "\n\n");
 | |
| 		ilits->all_frame_full = false;
 | |
| 		ilits->dbl[ilits->odi].mark = false;
 | |
| 		ilits->odi = ((ilits->odi + 1) % TR_BUF_LIST_SIZE);
 | |
| 	}
 | |
| 
 | |
| 	mutex_unlock(&ilits->debug_mutex);
 | |
| 	mutex_unlock(&ilits->debug_read_mutex);
 | |
| 	return 0;
 | |
| }
 | |
| #else
 | |
| static ssize_t ilitek_proc_debug_message_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	unsigned long p = *pos;
 | |
| 	int i = 0;
 | |
| 	int send_data_len = 0;
 | |
| 	int ret = 0;
 | |
| 	int data_count = 0;
 | |
| 	int one_data_bytes = 0;
 | |
| 	int need_read_data_len = 0;
 | |
| 	int type = 0;
 | |
| 	unsigned char *tmpbuf = NULL;
 | |
| 	unsigned char tmpbufback[128] = {0};
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (!ilits->dnp) {
 | |
| 		ILI_ERR("Debug flag isn't enabled (%d)\n", ilits->dnp);
 | |
| 		return -EAGAIN;
 | |
| 	}
 | |
| 
 | |
| 	if (ilits->odi == ilits->dbf && ilits->all_frame_full == false) {
 | |
| 		/* ILI_DBG("WARNING ! there's no cdc data.\n"); */
 | |
| 		*pos = send_data_len;
 | |
| 		return send_data_len;
 | |
| 	}
 | |
| 
 | |
| 	mutex_lock(&ilits->debug_read_mutex);
 | |
| 	ILI_DBG("f_count= %d, index = %d, mark = %d\n", ilits->dbf, ilits->odi, ilits->dbl[ilits->odi].mark);
 | |
| 	if (!wait_event_interruptible_timeout(ilits->inq, ilits->dbl[ilits->odi].mark, msecs_to_jiffies(ilits->wait_int_timeout))) {
 | |
| 		ILI_ERR("WARNING ! there's no data received.\n");
 | |
| 		mutex_unlock(&ilits->debug_read_mutex);
 | |
| 		*pos = send_data_len;
 | |
| 		return send_data_len;
 | |
| 	}
 | |
| 	mutex_lock(&ilits->debug_mutex);
 | |
| 
 | |
| 	tmpbuf = vmalloc(4096);	/* buf size if even */
 | |
| 	if (ERR_ALLOC_MEM(tmpbuf)) {
 | |
| 		ILI_ERR("buffer vmalloc error\n");
 | |
| 		send_data_len += snprintf(tmpbufback + send_data_len, sizeof(tmpbufback), "buffer vmalloc error\n");
 | |
| 		ret = copy_to_user(buff, tmpbufback, send_data_len); /*ilits->dbl[0] */
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	if (ilits->dbl[ilits->odi].mark) {
 | |
| 		if (ilits->dbl[ilits->odi].data[0] == P5_X_DEMO_PACKET_ID) {
 | |
| 			need_read_data_len = 43;
 | |
| 		} else if (ilits->dbl[ilits->odi].data[0] == P5_X_DEMO_HIGH_RESOLUTION_PACKET_ID) {
 | |
| 			need_read_data_len = P5_X_DEMO_MODE_PACKET_LEN_HIGH_RESOLUTION;
 | |
| 			if (ilits->rib.nCustomerType != ilits->customertype_off) {
 | |
| 				need_read_data_len += P5_X_CUSTOMER_LENGTH;
 | |
| 			}
 | |
| 		} else if (ilits->dbl[ilits->odi].data[0] == P5_X_I2CUART_PACKET_ID) {
 | |
| 			type = ilits->dbl[ilits->odi].data[3] & 0x0F;
 | |
| 
 | |
| 			data_count = ilits->dbl[ilits->odi].data[1] * ilits->dbl[ilits->odi].data[2];
 | |
| 
 | |
| 			if (type == 0 || type == 1 || type == 6) {
 | |
| 				one_data_bytes = 1;
 | |
| 			} else if (type == 2 || type == 3) {
 | |
| 				one_data_bytes = 2;
 | |
| 			} else if (type == 4 || type == 5) {
 | |
| 				one_data_bytes = 4;
 | |
| 			}
 | |
| 			need_read_data_len = data_count * one_data_bytes + 1 + 5;
 | |
| 		} else if (ilits->dbl[ilits->odi].data[0] == P5_X_DEBUG_PACKET_ID || ilits->dbl[ilits->odi].data[0] == P5_X_DEBUG_LITE_PACKET_ID) {
 | |
| 			send_data_len = 0;	/* ilits->dbl[0][1] - 2; */
 | |
| 			need_read_data_len = TR_BUF_SIZE - 8;
 | |
| 		} else if (ilits->dbl[ilits->odi].data[0] == P5_X_I2CUART_PACKET_ID) {
 | |
| 			need_read_data_len = P5_X_DEMO_MODE_PACKET_LEN+P5_X_DEMO_MODE_AXIS_LEN+P5_X_DEMO_MODE_STATE_INFO;
 | |
| 		}  else if (ilits->dbl[ilits->odi].data[0] == P5_X_DEBUG_HIGH_RESOLUTION_PACKET_ID) {
 | |
| 			send_data_len = 0;	/* ilits->dbl[0][1] - 2; */
 | |
| 			need_read_data_len = TR_BUF_SIZE - 8;
 | |
| 		}
 | |
| 
 | |
| 		for (i = 0; i < need_read_data_len; i++) {
 | |
| 			send_data_len += snprintf(tmpbuf + send_data_len, sizeof(tmpbufback), "%02X", ilits->dbl[ilits->odi].data[i]);
 | |
| 			if (send_data_len >= 4096) {
 | |
| 				ILI_ERR("send_data_len = %d set 4096 i = %d\n", send_data_len, i);
 | |
| 				send_data_len = 4096;
 | |
| 				break;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		send_data_len += snprintf(tmpbuf + send_data_len, sizeof(tmpbufback), "\n\n");
 | |
| 
 | |
| 		if (p == 5 || size == 4096 || size == 2048) {
 | |
| 			ilits->all_frame_full = false;
 | |
| 			ilits->dbl[ilits->odi].mark = false;
 | |
| 			ilits->odi = ((ilits->odi + 1) % TR_BUF_LIST_SIZE);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	/* Preparing to send debug data to user */
 | |
| 	if (size == 4096)
 | |
| 		ret = copy_to_user(buff, tmpbuf, send_data_len);
 | |
| 	else
 | |
| 		ret = copy_to_user(buff, tmpbuf + p, send_data_len - p);
 | |
| 
 | |
| 	/* ILI_ERR("send_data_len = %d\n", send_data_len); */
 | |
| 	if (send_data_len <= 0 || send_data_len > 4096) {
 | |
| 		ILI_ERR("send_data_len = %d set 4096\n", send_data_len);
 | |
| 		send_data_len = 4096;
 | |
| 	}
 | |
| 
 | |
| 	if (ret) {
 | |
| 		ILI_ERR("copy_to_user err\n");
 | |
| 		ret = -EFAULT;
 | |
| 	} else {
 | |
| 		*pos += send_data_len;
 | |
| 		ret = send_data_len;
 | |
| 		ILI_DBG("Read %d bytes(s) from %ld\n", send_data_len, p);
 | |
| 	}
 | |
| 
 | |
| out:
 | |
| 	mutex_unlock(&ilits->debug_mutex);
 | |
| 	mutex_unlock(&ilits->debug_read_mutex);
 | |
| 	ipio_vfree((void **)&tmpbuf);
 | |
| 	return send_data_len;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| static ssize_t ilitek_proc_get_debug_mode_data_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int ret;
 | |
| 	struct file_buffer csv;
 | |
| 	u8 data_type = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	/* initialize file */
 | |
| 	memset(csv.fname, 0, sizeof(csv.fname));
 | |
| 	snprintf(csv.fname, sizeof(csv.fname), "%s", DEBUG_DATA_FILE_PATH);
 | |
| 	csv.flen = 0;
 | |
| 	csv.wlen = 0;
 | |
| 	csv.max_size = DEBUG_DATA_FILE_SIZE;
 | |
| 
 | |
| 	csv.ptr = vmalloc(csv.max_size);
 | |
| 	if (ERR_ALLOC_MEM(csv.ptr)) {
 | |
| 		ILI_ERR("Failed to allocate CSV mem\n");
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	/* save data to csv */
 | |
| 	ILI_INFO("Get Raw data %d frame\n", ilits->raw_count);
 | |
| 	ILI_INFO("Get Delta data %d frame\n", ilits->delta_count);
 | |
| 	csv.wlen += snprintf(csv.ptr + csv.wlen, (csv.max_size - csv.wlen), "Get Raw data %d frame\n", ilits->raw_count);
 | |
| 	csv.wlen += snprintf(csv.ptr + csv.wlen, (csv.max_size - csv.wlen), "Get Delta data %d frame\n", ilits->delta_count);
 | |
| 
 | |
| 	file_write(&csv, true);
 | |
| 
 | |
| 	data_type = P5_X_FW_RAW_DATA_MODE;
 | |
| 	if (ili_set_tp_data_len(DATA_FORMAT_DEBUG, false, &data_type) < 0) {
 | |
| 		ILI_ERR("Failed to set tp data length\n");
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	/* get raw data */
 | |
| 	csv.wlen = 0;
 | |
| 	memset(csv.ptr, 0, csv.max_size);
 | |
| 	csv.wlen += snprintf(csv.ptr + csv.wlen, (csv.max_size - csv.wlen), "\n\n=======Raw data=======");
 | |
| 	file_write(&csv, false);
 | |
| 
 | |
| 	ret = debug_mode_get_data(&csv, P5_X_FW_RAW_DATA_MODE, ilits->raw_count);
 | |
| 	if (ret < 0)
 | |
| 		goto out;
 | |
| 
 | |
| 	/* get delta data */
 | |
| 	csv.wlen = 0;
 | |
| 	memset(csv.ptr, 0, csv.max_size);
 | |
| 	csv.wlen += snprintf(csv.ptr + csv.wlen, (csv.max_size - csv.wlen), "\n\n=======Delta data=======");
 | |
| 	file_write(&csv, false);
 | |
| 
 | |
| 	data_type = P5_X_FW_SIGNAL_DATA_MODE;
 | |
| 	if (ili_set_tp_data_len(DATA_FORMAT_DEBUG, false, &data_type) < 0) {
 | |
| 		ILI_ERR("Failed to set tp data length\n");
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	ret = debug_mode_get_data(&csv, P5_X_FW_SIGNAL_DATA_MODE, ilits->delta_count);
 | |
| 	if (ret < 0)
 | |
| 		goto out;
 | |
| 
 | |
| 	/* change to demo mode */
 | |
| 	data_type = P5_X_FW_SIGNAL_DATA_MODE;
 | |
| 	if (ili_set_tp_data_len(DATA_FORMAT_DEMO, false, &data_type) < 0)
 | |
| 		ILI_ERR("Failed to set tp data length\n");
 | |
| 
 | |
| out:
 | |
| 	ipio_vfree((void **)&csv.ptr);
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_get_debug_mode_data_write(struct file *filp, const char *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	char *token = NULL, *cur = NULL;
 | |
| 	char cmd[256] = {0};
 | |
| 	u8 temp[256] = {0}, count = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if ((size - 1) > sizeof(cmd)) {
 | |
| 		ILI_ERR("ERROR! input length is larger than local buffer\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	if (buff != NULL) {
 | |
| 		if (copy_from_user(cmd, buff, size - 1)) {
 | |
| 			ILI_INFO("Failed to copy data from user space\n");
 | |
| 			return -1;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	ILI_INFO("size = %d, cmd = %s\n", (int)size, cmd);
 | |
| 	token = cur = cmd;
 | |
| 	while ((token = strsep(&cur, ",")) != NULL) {
 | |
| 		temp[count] = ili_str2hex(token);
 | |
| 		ILI_INFO("temp[%d] = %d\n", count, temp[count]);
 | |
| 		count++;
 | |
| 	}
 | |
| 
 | |
| 	ilits->raw_count = ((temp[0] << 8) | temp[1]);
 | |
| 	ilits->delta_count = ((temp[2] << 8) | temp[3]);
 | |
| 	ilits->bg_count = ((temp[4] << 8) | temp[5]);
 | |
| 
 | |
| 	ILI_INFO("Raw_count = %d, Delta_count = %d, BG_count = %d\n", ilits->raw_count, ilits->delta_count, ilits->bg_count);
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| #if GENERIC_KERNEL_IMAGE
 | |
| static int ilitek_proc_mp_result_show(struct seq_file *m, void *v)
 | |
| {
 | |
| 	if (ilits->mp_result== NULL) {
 | |
| 		ILI_INFO("mp result is NULL\n");
 | |
| 		seq_printf(m, "mp result is NULL\n");
 | |
| 		return 0;
 | |
| 	}
 | |
| 
 | |
| 	if (m->size < 500 * K) {
 | |
| 		m->count = m->size;
 | |
| 		return 0;
 | |
| 	}
 | |
| 
 | |
| 	if (m->size < strlen(ilits->mp_result)) {
 | |
| 		ILI_INFO("size = %d, mp_result = %d\n Unable to print all data\n",
 | |
| 			(int) m->size, (int) strlen(ilits->mp_result));
 | |
| 		m->count = m->size;
 | |
| 		return 0;
 | |
| 	}
 | |
| 
 | |
| 	seq_printf(m, "%s", ilits->mp_result);
 | |
| 	return 0;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| static ssize_t ilitek_node_mp_lcm_on_test_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int ret = 0, len = 2;
 | |
| 	bool esd_en = ilits->wq_esd_ctrl, bat_en = ilits->wq_bat_ctrl;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	ILI_INFO("Run MP test with LCM on\n");
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	/* Create the directory for mp_test result */
 | |
| 	if ((dev_mkdir(CSV_LCM_ON_PATH, S_IRUGO | S_IWUSR)) != 0)
 | |
| 		ILI_ERR("Failed to create directory for mp_test\n");
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, DISABLE);
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 	ilits->mp_ret_len = 0;
 | |
| 
 | |
| 	ret = ili_mp_test_handler(g_user_buf, ON);
 | |
| 	ILI_INFO("MP TEST %s, Error code = %d\n", (ret < 0) ? "FAIL" : "PASS", ret);
 | |
| 
 | |
| 	g_user_buf[0] = 3;
 | |
| 	g_user_buf[1] = (ret < 0) ? -ret : ret;
 | |
| 	len += ilits->mp_ret_len;
 | |
| 
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "MP TEST %s\n", (ret < 0) ? "FAIL" : "PASS");
 | |
| 	if (g_user_buf[1] == EMP_MODE) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to switch MP mode, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_FW_PROC) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "FW still upgrading, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_FORMUL_NULL) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "MP formula is null, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_INI) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Not found ini file, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_NOMEM) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to allocated memory, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_PROTOCOL) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Protocol version isn't matched, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_TIMING_INFO) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to get timing info, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_PARA_NULL) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to get mp parameter, abort!");
 | |
| 	}
 | |
| 
 | |
| 	if (copy_to_user((char *)buff, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, ENABLE);
 | |
| 
 | |
| 	*pos += len;
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_node_mp_lcm_off_test_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int ret = 0, len = 2;
 | |
| 	bool esd_en = ilits->wq_esd_ctrl, bat_en = ilits->wq_bat_ctrl;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	ILI_INFO("Run MP test with LCM off\n");
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	/* Create the directory for mp_test result */
 | |
| 	if ((dev_mkdir(CSV_LCM_OFF_PATH, S_IRUGO | S_IWUSR)) != 0)
 | |
| 		ILI_ERR("Failed to create directory for mp_test\n");
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, DISABLE);
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 	ilits->mp_ret_len = 0;
 | |
| 
 | |
| 	ret = ili_mp_test_handler(g_user_buf, OFF);
 | |
| 	ILI_INFO("MP TEST %s, Error code = %d\n", (ret < 0) ? "FAIL" : "PASS", ret);
 | |
| 
 | |
| 	g_user_buf[0] = 3;
 | |
| 	g_user_buf[1] = (ret < 0) ? -ret : ret;
 | |
| 	len += ilits->mp_ret_len;
 | |
| 
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "MP TEST %s\n", (ret < 0) ? "FAIL" : "PASS");
 | |
| 	if (g_user_buf[1] == EMP_MODE) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to switch MP mode, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_FW_PROC) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "FW still upgrading, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_FORMUL_NULL) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "MP formula is null, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_INI) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Not found ini file, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_NOMEM) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to allocated memory, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_PROTOCOL) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Protocol version isn't matched, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_TIMING_INFO) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to get timing info, abort!");
 | |
| 	} else if (g_user_buf[1] == EMP_PARA_NULL) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to get mp parameter, abort!");
 | |
| 	}
 | |
| 
 | |
| 	if (copy_to_user((char *)buff, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, ENABLE);
 | |
| 
 | |
| 	*pos += len;
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_node_ver_info_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	u32 len = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "CHIP ID = %s\n", ilits->chip->product_id);
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "FW version = %d.%d.%d.%d\n",
 | |
| 			ilits->chip->fw_ver >> 24, (ilits->chip->fw_ver >> 16) & 0xFF,
 | |
| 			(ilits->chip->fw_ver >> 8) & 0xFF, ilits->chip->fw_ver & 0xFF);
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "FW MP version = %d.%d.%d.%d\n",
 | |
| 			ilits->chip->fw_mp_ver >> 24, (ilits->chip->fw_mp_ver >> 16) & 0xFF,
 | |
| 			(ilits->chip->fw_mp_ver >> 8) & 0xFF, ilits->chip->fw_mp_ver & 0xFF);
 | |
| 
 | |
| 	if (ilits->protocol->core_ver_len == P5_X_CORE_VER_THREE_LENGTH)
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "Core version = %d.%d.%d\n",
 | |
| 			(ilits->chip->core_ver >> 24) & 0xFF, (ilits->chip->core_ver >> 16) & 0xFF,
 | |
| 			(ilits->chip->core_ver >> 8) & 0xFF);
 | |
| 	else
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "Core version = %d.%d.%d.%d\n",
 | |
| 			(ilits->chip->core_ver >> 24) & 0xFF, (ilits->chip->core_ver >> 16) & 0xFF,
 | |
| 			(ilits->chip->core_ver >> 8) & 0xFF, ilits->chip->core_ver & 0xFF);
 | |
| 
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "Protocol version = %d.%d.%d\n",
 | |
| 			ilits->protocol->ver >> 16, (ilits->protocol->ver >> 8) & 0xFF,
 | |
| 			ilits->protocol->ver & 0xFF);
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "Driver version = %s\n", DRIVER_VERSION);
 | |
| 
 | |
| 	if (copy_to_user((char *)buff, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	*pos += len;
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_node_change_list_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	u32 len = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "============= Change list ==============\n");
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "[Drive version] = %s\n", DRIVER_VERSION);
 | |
| 	/* len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "[Patch] 202001-0001\n"); */
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "========================================\n");
 | |
| 
 | |
| 	if (copy_to_user((char *)buff, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	*pos += len;
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_fw_process_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	u32 len = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	len = snprintf(g_user_buf, USER_STR_BUFF * sizeof(unsigned char), "%02d\n", ilits->fw_update_stat);
 | |
| 
 | |
| 	ILI_INFO("update status = %d\n", ilits->fw_update_stat);
 | |
| 
 | |
| 	if (copy_to_user((char *)buff, &ilits->fw_update_stat, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	*pos = len;
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_node_fw_upgrade_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int ret = 0, len = 0;
 | |
| 	bool esd_en = ilits->wq_esd_ctrl, bat_en = ilits->wq_bat_ctrl;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	ILI_INFO("Prepar to upgarde firmware\n");
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, DISABLE);
 | |
| 
 | |
| 	ilits->force_fw_update = ENABLE;
 | |
| 	ilits->node_update = true;
 | |
| 
 | |
| 	ret = ili_fw_upgrade_handler(NULL);
 | |
| 
 | |
| 	ilits->node_update = false;
 | |
| 	ilits->force_fw_update = DISABLE;
 | |
| 
 | |
| 	ret = (ret < 0) ? -ret : ret;
 | |
| 
 | |
| 	len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%3d ", (ret == 0) ? 1 : ret);
 | |
| 
 | |
| 	if (ret == 0)
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Upgrade firmware = PASS");
 | |
| 	else
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Upgrade firmware = FAIL");
 | |
| 
 | |
| 	/* Reason for fail */
 | |
| 	if (ret == EFW_CONVERT_FILE) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to convert hex/ili file, abort!");
 | |
| 	} else if (ret == ENOMEM) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to allocate memory, abort!");
 | |
| 	} else if (ret == EFW_ICE_MODE) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to operate ice mode, abort!");
 | |
| 	} else if (ret == EFW_CRC) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "CRC not matched, abort!");
 | |
| 	} else if (ret == EFW_REST) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to do reset, abort!");
 | |
| 	} else if (ret == EFW_ERASE) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to erase flash, abort!");
 | |
| 	} else if (ret == EFW_PROGRAM) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to program flash, abort!");
 | |
| 	} else if (ret == EFW_INTERFACE) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to hex file interface no match, abort!");
 | |
| 	}
 | |
| 
 | |
| 	if (copy_to_user((u32 *) buff, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, ENABLE);
 | |
| 
 | |
| 	*pos += len;
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_debug_level_read(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	debug_en = !debug_en;
 | |
| 
 | |
| 	ILI_INFO(" %s debug level = %x\n", debug_en ? "Enable" : "Disable", debug_en);
 | |
| 
 | |
| 	size = snprintf(g_user_buf, USER_STR_BUFF * sizeof(unsigned char), "debug level : %s\n", debug_en ? "Enable" : "Disable");
 | |
| 
 | |
| 	*pos += size;
 | |
| 
 | |
| 	if (copy_to_user((u32 *) buff, g_user_buf, size))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_proc_sram_test_info(struct file *filp, char __user *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int len = 0, ret = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (*pos != 0)
 | |
| 		return 0;
 | |
| 
 | |
| 	memset(g_user_buf, 0, USER_STR_BUFF * sizeof(unsigned char));
 | |
| 
 | |
| 	if (ilits->cascade_info_block.nNum != 0) {
 | |
| 		ret = ili_cascade_reset_ctrl(TP_IC_WHOLE_RST_WITH_FLASH, true);
 | |
| 	} else {
 | |
| 		ret = ili_reset_ctrl(TP_IC_WHOLE_RST_WITH_FLASH);
 | |
| 	}
 | |
| 
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("TP_IC_WHOLE_RST_WITH_FLASH Failed, ret = %d\n", ret);
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "TP_IC_WHOLE_RST_WITH_FLASH Failed");
 | |
| 	}
 | |
| 
 | |
| 	mdelay(30);
 | |
| 
 | |
| 	ili_parsing_sram_param();
 | |
| 
 | |
| 	if (ilits->cascade_info_block.nNum != 0) {
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 		ili_ice_mode_ctrl_by_mode(ENABLE, OFF, BOTH);
 | |
| #else
 | |
| 		ili_core_spi_setup(SPI_CLK_CASCADE_TABLE_NUM);
 | |
| 		ilits->ice_mode_ctrl(ENABLE, OFF, BOTH);
 | |
| #endif
 | |
| 	} else {
 | |
| 		ret = ili_ice_mode_ctrl(ENABLE, OFF);
 | |
| 	}
 | |
| 
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("Failed to disable ICE mode, ret = %d\n", ret);
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "Failed to disable ICE mode");
 | |
| 	}
 | |
| 
 | |
| 	/* close FW SRAM power saving */
 | |
| 	/* 7807Q 9881N don't have to close it */
 | |
| 	if (ilits->sram_para.tpu_clock_en == ENABLE) {
 | |
| 		ILI_INFO("close FW SRAM power saving\n");
 | |
| 		ili_ice_mode_write_by_mode(0x8003F, 0x8A, 1, BOTH);
 | |
| 		ili_ice_mode_write_by_mode(0x8003C, 0x00, 1, BOTH);
 | |
| 	}
 | |
| 
 | |
| 	ret = ili_tddi_ic_sram_test();
 | |
| 	if (ret < 0) {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "SRAM TEST Failed");
 | |
| 	} else {
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "SRAM TEST Pass");
 | |
| 	}
 | |
| 
 | |
| 	if (ilits->cascade_info_block.nNum != 0) {
 | |
| 		ret = ili_cascade_reset_ctrl(TP_IC_WHOLE_RST_WITH_FLASH, false);
 | |
| 		ilits->ice_mode_ctrl(ENABLE, OFF, BOTH);
 | |
| 	} else {
 | |
| 		ret = ili_reset_ctrl(TP_IC_WHOLE_RST_WITH_FLASH);
 | |
| 	}
 | |
| 
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("TP_IC_WHOLE_RST_WITH_FLASH Failed, ret = %d\n", ret);
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "TP_IC_WHOLE_RST_WITH_FLASH Failed");
 | |
| 	}
 | |
| 
 | |
| 	mdelay(50);
 | |
| 
 | |
| 	ret = ili_fw_upgrade_handler(NULL);
 | |
| 	if (ret < 0) {
 | |
| 		ILI_ERR("fw upgrade Failed, ret = %d\n", ret);
 | |
| 		len += snprintf(g_user_buf + len, USER_STR_BUFF - len, "%s\n", "fw upgrade Failed");
 | |
| 	}
 | |
| 
 | |
| 	if (copy_to_user((char *)buff, g_user_buf, len))
 | |
| 		ILI_ERR("Failed to copy data to user space\n");
 | |
| 
 | |
| 	*pos += len;
 | |
| 	return len;
 | |
| }
 | |
| 
 | |
| int ili_get_tp_recore_ctrl(int data)
 | |
| {
 | |
| 	int ret = 0;
 | |
| 
 | |
| 	switch ((int)data) {
 | |
| 
 | |
| 	case ENABLE_RECORD:
 | |
| 		ILI_INFO("recore enable");
 | |
| 		ret = ili_ic_func_ctrl("tp_recore", 1);
 | |
| 		mdelay(200);
 | |
| 		break;
 | |
| 	case DATA_RECORD:
 | |
| 		mdelay(50);
 | |
| 		ILI_INFO("Get data");
 | |
| 		ret = ili_ic_func_ctrl("tp_recore", 2);
 | |
| 		if (ret < 0) {
 | |
| 			ILI_ERR("cmd fail\n");
 | |
| 			goto out;
 | |
| 		}
 | |
| 
 | |
| 		ret = ili_get_tp_recore_data(ON);
 | |
| 		if (ret < 0)
 | |
| 			ILI_ERR("get data fail\n");
 | |
| 
 | |
| 		ILI_INFO("recore reset");
 | |
| 		ret = ili_ic_func_ctrl("tp_recore", 3);
 | |
| 		if (ret < 0) {
 | |
| 			ILI_ERR("cmd fail\n");
 | |
| 			goto out;
 | |
| 		}
 | |
| 		break;
 | |
| 	case DISABLE_RECORD:
 | |
| 		ILI_INFO("recore disable");
 | |
| 		ret = ili_ic_func_ctrl("tp_recore", 0);
 | |
| 		break;
 | |
| 
 | |
| 	}
 | |
| out:
 | |
| 	return ret;
 | |
| 
 | |
| }
 | |
| 
 | |
| int ili_get_tp_recore_data(bool mcu)
 | |
| {
 | |
| 	u8 buf[8] = {0}, record_case = 0;
 | |
| 	s8 index;
 | |
| 	u16 *raw = NULL, *raw_ptr = NULL, frame_len = 0;
 | |
| 	u32 base_addr = 0x20000, addr, len, i, fcnt;
 | |
| 	struct record_state record_stat;
 | |
| 	bool ice = atomic_read(&ilits->ice_stat);
 | |
| 
 | |
| 	if (ilits->wrapper(NULL, 0, buf, sizeof(buf), OFF, OFF) < 0) {
 | |
| 		ILI_ERR("Get info fail\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	addr = ((buf[0] << 8) | buf[1]) + base_addr;
 | |
| 	len = ((buf[2] << 8) | buf[3]);
 | |
| 	index = buf[4];
 | |
| 	fcnt = buf[5];
 | |
| 	record_case = buf[6];
 | |
| 	ipio_memcpy(&record_stat, &buf[7], 1, 1);
 | |
| 	ILI_INFO("addr = 0x%x, len = %d, lndex = 0x%x, fram num = %d, record_case = 0x%x\n",
 | |
| 		addr, len, index, fcnt, record_case);
 | |
| 	ili_dump_data(buf, 8, sizeof(buf), 0, "all record bytes");
 | |
| 
 | |
| 	raw = kcalloc(len, sizeof(u8), GFP_ATOMIC);
 | |
| 	if (ERR_ALLOC_MEM(raw)) {
 | |
| 		ILI_ERR("Failed to allocate packet memory, %ld\n", PTR_ERR(raw));
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	if (!ice)
 | |
| 		ili_ice_mode_ctrl(ENABLE, ON);
 | |
| 
 | |
| 	buf[0] = 0x25;
 | |
| 	buf[3] = (char)((addr & 0x00FF0000) >> 16);
 | |
| 	buf[2] = (char)((addr & 0x0000FF00) >> 8);
 | |
| 	buf[1] = (char)((addr & 0x000000FF));
 | |
| 
 | |
| 	if (ilits->wrapper(buf, 4, NULL, 0, ON, OFF)) {
 | |
| 		ILI_ERR("Failed to write iram data\n");
 | |
| 		return -ENODEV;
 | |
| 	}
 | |
| 
 | |
| 	if (ilits->wrapper(NULL, 0, (u8 *)raw, len, ON, OFF)) {
 | |
| 		ILI_ERR("Failed to Read iram data\n");
 | |
| 		return -ENODEV;
 | |
| 	}
 | |
| 
 | |
| 	frame_len = (len / (fcnt * 2));
 | |
| 	for (i = 0; i < fcnt; i++) {
 | |
| 		raw_ptr = raw + (index * frame_len);
 | |
| 
 | |
| 		ili_dump_data(raw_ptr, 16, frame_len, ilits->xch_num, "recore_data");
 | |
| 		index--;
 | |
| 		if (index < 0)
 | |
| 			index = fcnt - 1;
 | |
| 	}
 | |
| 
 | |
| 	if (!ice)
 | |
| 		ili_ice_mode_ctrl(DISABLE, ON);
 | |
| 
 | |
| 	if (record_case == 2) {
 | |
| 		ILI_INFO("tp_palm_stat = %d\n", record_stat.touch_palm_state_e);
 | |
| 		ILI_INFO("app_an_stat = %d\n", record_stat.app_an_statu_e);
 | |
| 		ILI_INFO("app_check_abnor = %d\n", record_stat.app_sys_check_bg_abnormal);
 | |
| 		ILI_INFO("wrong_bg = %d\n", record_stat.g_b_wrong_bg);
 | |
| 	}
 | |
| 
 | |
| 	ipio_kfree((void **)&raw);
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| void ili_gesture_fail_reason(bool enable)
 | |
| {
 | |
| 
 | |
| 	u8 cmd[24] = {0};
 | |
| 
 | |
| 	/* set symbol */
 | |
| 	if (ili_ic_func_ctrl("knock_en", 0x8) < 0)
 | |
| 		ILI_ERR("set symbol failed");
 | |
| 
 | |
| 	/* enable gesture fail reason */
 | |
| 	cmd[0] = 0x01;
 | |
| 	cmd[1] = 0x0A;
 | |
| 	cmd[2] = 0x10;
 | |
| 	if (enable)
 | |
| 		cmd[3] = 0x01;
 | |
| 	else
 | |
| 		cmd[3] = 0x00;
 | |
| 	cmd[4] = 0xFF;
 | |
| 	cmd[5] = 0xFF;
 | |
| 	if ((ilits->wrapper(cmd, 6, NULL, 0, ON, OFF)) < 0)
 | |
| 		ILI_ERR("enable gesture fail reason failed");
 | |
| 
 | |
| 	/* set gesture parameters */
 | |
| 	cmd[0] = 0x01;
 | |
| 	cmd[1] = 0x0A;
 | |
| 	cmd[2] = 0x12;
 | |
| 	cmd[3] = 0x01;
 | |
| 	memset(cmd + 4, 0xFF, 20);
 | |
| 	if ((ilits->wrapper(cmd, 24, NULL, 0, ON, OFF)) < 0)
 | |
| 		ILI_ERR("set gesture parameters failed");
 | |
| 
 | |
| 	/* get gesture parameters */
 | |
| 	cmd[0] = 0x01;
 | |
| 	cmd[1] = 0x0A;
 | |
| 	cmd[2] = 0x11;
 | |
| 	cmd[3] = 0x01;
 | |
| 	if ((ilits->wrapper(cmd, 4, NULL, 0, ON, OFF)) < 0)
 | |
| 		ILI_ERR("get gesture parameters failed");
 | |
| 
 | |
| }
 | |
| 
 | |
| int ili_tp_data_mode_ctrl(u8 *cmd)
 | |
| {
 | |
| 	int ret = 0;
 | |
| #if (TDDI_INTERFACE == BUS_SPI)
 | |
| 	int check_debugLite = -1;
 | |
| #endif
 | |
| 	switch (cmd[0]) {
 | |
| 	case AP_MODE:
 | |
| 		if (ilits->tp_suspend) {
 | |
| 			if (ili_set_tp_data_len(DATA_FORMAT_GESTURE_DEMO, false, &cmd[1]) < 0) {
 | |
| 				ILI_ERR("Failed to set demo len from gesture mode\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		} else {
 | |
| 			if (ilits->actual_tp_mode == P5_X_FW_TEST_MODE) {
 | |
| 				if (ili_switch_tp_mode(P5_X_FW_AP_MODE) < 0) {
 | |
| 					ILI_ERR("Failed to switch demo mode\n");
 | |
| 					ret = -ENOTTY;
 | |
| 				}
 | |
| 			} else {
 | |
| 				if (ili_set_tp_data_len(DATA_FORMAT_DEMO, false, &cmd[1]) < 0) {
 | |
| 					ILI_ERR("Failed to switch demo mode\n");
 | |
| 					ret = -ENOTTY;
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		break;
 | |
| 	case TEST_MODE:
 | |
| 		if (ili_switch_tp_mode(P5_X_FW_TEST_MODE) < 0) {
 | |
| 			ILI_ERR("Failed to switch test mode\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case DEBUG_MODE:
 | |
| 		if (!ilits->tp_suspend && (ilits->actual_tp_mode != P5_X_FW_AP_MODE)) {
 | |
| 			if (ili_switch_tp_mode(P5_X_FW_AP_MODE) < 0) {
 | |
| 				ILI_ERR("Failed to switch Debug mode\n");
 | |
| 				ret = -ENOTTY;
 | |
| 				break;
 | |
| 			}
 | |
| 		}
 | |
| 		if (ilits->tp_suspend) {
 | |
| 			if (ili_set_tp_data_len(DATA_FORMAT_GESTURE_DEBUG, false, &cmd[1]) < 0) {
 | |
| 				ILI_ERR("Failed to set debug len from gesture mode\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		} else {
 | |
| 			if (ili_set_tp_data_len(DATA_FORMAT_DEBUG, false, &cmd[1]) < 0) {
 | |
| 				ILI_ERR("Failed to set debug len\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		}
 | |
| 		break;
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 	case DEBUG_LITE_ROI:
 | |
| 		if (ili_set_tp_data_len(DATA_FORMAT_DEBUG_LITE_ROI, false, &cmd[1]) < 0) {
 | |
| 			ILI_ERR("Failed to set debug lite roi\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case DEBUG_LITE_WINDOW:
 | |
| 		if (ili_set_tp_data_len(DATA_FORMAT_DEBUG_LITE_WINDOW, false, &cmd[1]) < 0) {
 | |
| 			ILI_ERR("Failed to set debug lite window\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case DEBUG_LITE_AREA:
 | |
| 		if (ili_set_tp_data_len(DATA_FORMAT_DEBUG_LITE_AREA, false, &cmd[1]) < 0) {
 | |
| 			ILI_ERR("Failed to set debug lite area\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case DEBUG_LITE_PEN:
 | |
| 		if (ilits->PenType == POSITION_PEN_TYPE_ON) {
 | |
| 			if (ili_set_tp_data_len(DATA_FORMAT_DEBUG_LITE_PEN, false, &cmd[1]) < 0) {
 | |
| 				ILI_ERR("Failed to set debug lite pen\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		}
 | |
| 		break;
 | |
| #else
 | |
| 	case DEBUG_LITE_ROI:
 | |
| 		check_debugLite = ili_ic_check_debug_lite_support(DATA_FORMAT_DEBUG_LITE_ROI, false, &cmd[1]);
 | |
| 		if ( check_debugLite == ENABLE) {
 | |
| 			if (ili_set_tp_data_len(DATA_FORMAT_DEBUG_LITE_ROI, false, &cmd[1]) < 0) {
 | |
| 				ILI_ERR("Failed to set debug lite roi\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		} else if (check_debugLite == DISABLE){
 | |
| 			ILI_INFO("no support DEBUG LITE ROI mode, set to debug mode\n");
 | |
| 			cmd[0] = DEBUG_MODE;
 | |
| 			ili_tp_data_mode_ctrl(cmd);
 | |
| 		} else {
 | |
| 			ILI_ERR("change DEBUG LITE ROI fail\n");
 | |
| 		}
 | |
| 
 | |
| 		break;
 | |
| 	case DEBUG_LITE_WINDOW:
 | |
| 		check_debugLite = ili_ic_check_debug_lite_support(DATA_FORMAT_DEBUG_LITE_WINDOW, false, &cmd[1]);
 | |
| 		if ( check_debugLite == ENABLE) {
 | |
| 			if (ili_set_tp_data_len(DATA_FORMAT_DEBUG_LITE_WINDOW, false, &cmd[1]) < 0) {
 | |
| 				ILI_ERR("Failed to set debug lite window\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		} else if (check_debugLite == DISABLE){
 | |
| 			ILI_INFO("no support DEBUG LITE WINDOW mode, set to debug mode\n");
 | |
| 			cmd[0] = DEBUG_MODE;
 | |
| 			ili_tp_data_mode_ctrl(cmd);
 | |
| 		} else {
 | |
| 			ILI_ERR("change DEBUG LITE WINDOW fail\n");
 | |
| 		}
 | |
| 		break;
 | |
| 	case DEBUG_LITE_AREA:
 | |
| 		check_debugLite = ili_ic_check_debug_lite_support(DATA_FORMAT_DEBUG_LITE_AREA, false, &cmd[1]);
 | |
| 		if ( check_debugLite == ENABLE) {
 | |
| 			if (ili_set_tp_data_len(DATA_FORMAT_DEBUG_LITE_AREA, false, &cmd[1]) < 0) {
 | |
| 				ILI_ERR("Failed to set debug lite area\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		} else if (check_debugLite == DISABLE){
 | |
| 			ILI_INFO("no support DEBUG LITE AREA mode, set to debug mode\n");
 | |
| 			cmd[0] = DEBUG_MODE;
 | |
| 			ili_tp_data_mode_ctrl(cmd);
 | |
| 		} else {
 | |
| 			ILI_ERR("change DEBUG LITE AREA fail\n");
 | |
| 		}
 | |
| 		break;
 | |
| 	case DEBUG_LITE_PEN:
 | |
| 		ILI_INFO("SPI no support debug lite pen\n");
 | |
| 		break;
 | |
| #endif
 | |
| 	case DEBUG_PEN_ONLY_MODE:
 | |
| 		if (ilits->PenType == POSITION_PEN_TYPE_ON) {
 | |
| 			ilits->pen_info.report_type = P5_X_ONLY_PEN_TYPE;
 | |
| 			if (ili_set_pen_data_len(P5_X_NEW_CONTROL_FORMAT, DATA_FORMAT_DEBUG_PEN_CMD, cmd[1]) < 0) {
 | |
| 				ILI_ERR("Failed to set debug pen, Data Type : 0x%X\n", cmd[1]);
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		} else {
 | |
| 			ILI_INFO("no support debug pen only\n");
 | |
| 		}
 | |
| 		break;
 | |
| 	case DEBUG_HAND_ONLY_MODE:
 | |
| 		ilits->pen_info.report_type = P5_X_ONLY_HAND_TYPE;
 | |
| 		if (ili_set_pen_data_len(P5_X_NEW_CONTROL_FORMAT, DATA_FORMAT_DEBUG_HAND_CMD, cmd[1]) < 0) {
 | |
| 			ILI_ERR("Failed to set debug hand data\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	default:
 | |
| 		ILI_ERR("Unknown TP mode ctrl\n");
 | |
| 		ret = -ENOTTY;
 | |
| 		break;
 | |
| 	}
 | |
| 	ilits->tp_data_mode = cmd[0];
 | |
| 
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| int ili_mp_lcm_off_env_ctrl(u8 lcm_on)
 | |
| {
 | |
| 	int ret = 0;
 | |
| 	ILI_INFO("set mp lcm off env to %d\n", lcm_on);
 | |
| 	if (lcm_on == ENABLE) {
 | |
| 		if (ENABLE_WQ_ESD)
 | |
| 			ilits->esd_func_ctrl = ENABLE;
 | |
| 
 | |
| 		/* enable esd recovery */
 | |
| 		ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	} else {
 | |
| 		/* disable esd recovery */
 | |
| 		ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 
 | |
| 		if (ENABLE_WQ_ESD)
 | |
| 			ilits->esd_func_ctrl = DISABLE;
 | |
| 
 | |
| 		/* enable gesture */
 | |
| 		ilits->gesture = ENABLE;
 | |
| 	}
 | |
| 	return ret;
 | |
| 
 | |
| }
 | |
| 
 | |
| static ssize_t ilitek_node_ioctl_write(struct file *filp, const char *buff, size_t size, loff_t *pos)
 | |
| {
 | |
| 	int i, ret = 0, count = 0;
 | |
| 	char cmd[512] = {0};
 | |
| 	char *token = NULL, *cur = NULL;
 | |
| 	u8 temp[256] = {0};
 | |
| 	u32 *data = NULL;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if ((size - 1) > sizeof(cmd)) {
 | |
| 		ILI_ERR("ERROR! input length is larger than local buffer\n");
 | |
| 		return -1;
 | |
| 	}
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	if (buff != NULL) {
 | |
| 		if (copy_from_user(cmd, buff, size - 1)) {
 | |
| 			ILI_INFO("Failed to copy data from user space\n");
 | |
| 			return -1;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	ILI_INFO("size = %d, cmd = %s\n", (int)size, cmd);
 | |
| 
 | |
| 	token = cur = cmd;
 | |
| 
 | |
| 	data = kcalloc(512, sizeof(u32), GFP_KERNEL);
 | |
| 	if (ERR_ALLOC_MEM(data)) {
 | |
| 		ILI_ERR("Failed to allocate data mem\n");
 | |
| 		size = -1;
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	while ((token = strsep(&cur, ",")) != NULL) {
 | |
| 		data[count] = ili_str2hex(token);
 | |
| 		ILI_INFO("data[%d] = %x\n", count, data[count]);
 | |
| 		count++;
 | |
| 	}
 | |
| 
 | |
| 	ILI_INFO("cmd = %s\n", cmd);
 | |
| 
 | |
| 	if (strncmp(cmd, "hwreset", strlen(cmd)) == 0) {
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| 			ili_cascade_reset_ctrl(TP_HW_RST_ONLY, true);
 | |
| 		} else {
 | |
| 			ili_reset_ctrl(TP_HW_RST_ONLY);
 | |
| 		}
 | |
| 	} else if (strcmp(cmd, "rawdatarecore") == 0) {
 | |
| 		if (data[1] == ENABLE_RECORD)
 | |
| 			ili_get_tp_recore_ctrl(ENABLE_RECORD);
 | |
| 		else if (data[1] == DATA_RECORD)
 | |
| 			ili_get_tp_recore_ctrl(DATA_RECORD);
 | |
| 		else if (data[1] == DISABLE_RECORD)
 | |
| 			ili_get_tp_recore_ctrl(DISABLE_RECORD);
 | |
| 	} else if (strcmp(cmd, "switchdemodebuginfomode") == 0) {
 | |
| 		u8 data_type;
 | |
| 		data_type = data[1] & 0xFF;
 | |
| 		ili_set_tp_data_len(DATA_FORMAT_DEMO_DEBUG_INFO, false, &data_type);
 | |
| 	} else if (strcmp(cmd, "gesturedemoen") == 0) {
 | |
| 		u8 data_type;
 | |
| 		data_type = data[2] & 0xFF;
 | |
| 		if (data[1] == DISABLE)
 | |
| 			ilits->gesture_demo_ctrl = DISABLE;
 | |
| 		else
 | |
| 			ilits->gesture_demo_ctrl = ENABLE;
 | |
| 		ili_set_tp_data_len(DATA_FORMAT_GESTURE_DEMO, false, &data_type);
 | |
| 	} else if (strcmp(cmd, "gesturefailrsn") == 0) {
 | |
| 		if (data[1] == DISABLE)
 | |
| 			ili_gesture_fail_reason(DISABLE);
 | |
| 		else
 | |
| 			ili_gesture_fail_reason(ENABLE);
 | |
| 		ILI_INFO("%s gesture fail reason\n", data[1] ? "ENABLE" : "DISABLE");
 | |
| 	} else if (strncmp(cmd, "icwholereset", strlen(cmd)) == 0) {
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| 			ili_cascade_reset_ctrl(TP_IC_WHOLE_RST_WITH_FLASH, true);
 | |
| 		} else {
 | |
| 			ili_ice_mode_ctrl(ENABLE, OFF);
 | |
| 			ili_reset_ctrl(TP_IC_WHOLE_RST_WITH_FLASH);
 | |
| 		}
 | |
|     } else if (strncmp(cmd, "icwholeresetwithoutflash", strlen(cmd)) == 0) {
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| 			ili_cascade_reset_ctrl(TP_IC_WHOLE_RST_WITHOUT_FLASH, true);
 | |
| 		} else {
 | |
| 			ili_ice_mode_ctrl(ENABLE, OFF);
 | |
| 			ili_reset_ctrl(TP_IC_WHOLE_RST_WITHOUT_FLASH);
 | |
| 		}
 | |
| 	} else if (strncmp(cmd, "iccodereset", strlen(cmd)) == 0) {
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| 			ili_cascade_reset_ctrl(TP_IC_CODE_RST, true);
 | |
| 		} else {
 | |
| 			ili_ice_mode_ctrl(ENABLE, OFF);
 | |
| 			ili_reset_ctrl(TP_IC_CODE_RST);
 | |
| 			ili_ice_mode_ctrl(DISABLE, OFF);
 | |
| 		}
 | |
| 	} else if (strncmp(cmd, "enableirq", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("Enable IRQ\n");
 | |
| 		ili_irq_enable();
 | |
| 	} else if (strncmp(cmd, "disableirq", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("Disable IRQ\n");
 | |
| 		ili_irq_disable();
 | |
| 	} else if (strncmp(cmd, "infofromhex", strlen(cmd)) == 0) {
 | |
| 		ilits->info_from_hex = data[1];
 | |
| 		ILI_INFO("info from hex = %d\n", data[1]);
 | |
| 	} else if (strncmp(cmd, "getinfo", strlen(cmd)) == 0) {
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 		ilits->info_from_hex = DISABLE;
 | |
| #endif
 | |
| 
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| 			if (ili_cascade_ic_get_info(true, true) < 0)
 | |
| 				ILI_ERR("Slave Chip info is incorrect\n");
 | |
| 		} else {
 | |
| 			ili_ice_mode_ctrl(ENABLE, OFF);
 | |
| 			ili_ic_get_info();
 | |
| 			ili_ice_mode_ctrl(DISABLE, OFF);
 | |
| 		}
 | |
| 
 | |
| 		ili_ic_get_all_info();
 | |
| 		ILI_INFO("Driver version = %s\n", DRIVER_VERSION);
 | |
| 		ILI_INFO("TP module = %s\n", ilits->md_name);
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 		ilits->info_from_hex = ENABLE;
 | |
| #endif
 | |
| 	} else if (strncmp(cmd, "enableicemode", strlen(cmd)) == 0) {
 | |
| 		bool mcu;
 | |
| 		u8 mode;
 | |
| 		mcu = data[1] & BIT(0);
 | |
| 		mode = data[2] & 0x0F;
 | |
| 
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 		ili_ice_mode_ctrl_by_mode(ENABLE, mcu, mode);
 | |
| #else
 | |
| 		if (mode == MASTER) {
 | |
| 			ilits->ice_mode_ctrl(ENABLE, mcu, MASTER);
 | |
| 		} else {
 | |
| 			ilits->ice_mode_ctrl(ENABLE, mcu, BOTH);
 | |
| 		}
 | |
| #endif
 | |
| 		} else {
 | |
| 			ili_ice_mode_ctrl(ENABLE, mcu);
 | |
| 		}
 | |
| 	} else if (strncmp(cmd, "wqctrl", strlen(cmd)) == 0) {
 | |
| 		ilits->wq_ctrl = !ilits->wq_ctrl;
 | |
| 		ILI_INFO("wq_ctrl flag= %d\n", ilits->wq_ctrl);
 | |
| 	} else if (strcmp(cmd, "spiwrslavereg") == 0 || strcmp(cmd, "slavectrl") == 0) {
 | |
| 		ilits->slave_wr_ctrl = (data[1] == ENABLE) ? SLAVE: MASTER;
 | |
| 		ILI_INFO(" %s slave write read ctrl = %x\n", ilits->slave_wr_ctrl ? "Enable" : "Disable", ilits->slave_wr_ctrl);
 | |
| 	}
 | |
| 	else if (strncmp(cmd, "file_write", strlen(cmd)) == 0) {
 | |
|                 /*For Wacom Test Pen ID*/
 | |
|                 struct file_buffer csv;
 | |
| 
 | |
| 		memset(csv.fname, 0, sizeof(csv.fname));
 | |
| 		snprintf(csv.fname, sizeof(csv.fname), "%s", PEN_ID_NODE_TEST_PATH);
 | |
| 		csv.wlen = 0;
 | |
| 		csv.max_size = TXT_FILE_SIZE;
 | |
| 
 | |
| 		csv.ptr = vmalloc(csv.max_size);
 | |
| 		if (ERR_ALLOC_MEM(csv.ptr)) {
 | |
| 			ILI_ERR("Failed to allocate CSV mem\n");
 | |
| 			ipio_vfree((void **)&csv.ptr);
 | |
| 		}
 | |
| 
 | |
| 		memset(csv.ptr, 0, csv.max_size);
 | |
| 		csv.wlen += snprintf(csv.ptr + csv.wlen, (csv.max_size - csv.wlen), "PEN_ID = 0x");
 | |
| 		for(i = 0; i < P5_X_PEN_ID_LEN; i++) {
 | |
| 			ILI_INFO("Pen ID[%d] = 0x%02X", i, ilits->pen_info.pen_id[P5_X_PEN_ID_LEN - 1 - i]);
 | |
| 			csv.wlen += snprintf(csv.ptr + csv.wlen, (csv.max_size - csv.wlen), "%02X", ilits->pen_info.pen_id[P5_X_PEN_ID_LEN - 1 - i]);
 | |
| 		}
 | |
| 		ILI_INFO("\n");
 | |
| 		csv.wlen += snprintf(csv.ptr + csv.wlen, (csv.max_size - csv.wlen), "\n");
 | |
| 		file_write(&csv, true);
 | |
| 
 | |
| 	}else if (strncmp(cmd, "disableicemode", strlen(cmd)) == 0) {
 | |
| 		bool mcu;
 | |
| 		//u8 mode;
 | |
| 		mcu = data[1] & BIT(0);
 | |
| 		//mode = data[2] & 0x0F;
 | |
| 
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 		ili_ice_mode_ctrl_by_mode(DISABLE, mcu, mode);
 | |
| #else
 | |
| 		ili_ice_mode_ctrl(DISABLE, mcu);
 | |
| #endif
 | |
| 		} else {
 | |
| 			ili_ice_mode_ctrl(DISABLE, mcu);
 | |
| 		}
 | |
| 	} else if (strncmp(cmd, "enablewqesd", strlen(cmd)) == 0) {
 | |
| 		ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	} else if (strncmp(cmd, "enablewqbat", strlen(cmd)) == 0) {
 | |
| 		ili_wq_ctrl(WQ_BAT, ENABLE);
 | |
| 	} else if (strncmp(cmd, "disablewqesd", strlen(cmd)) == 0) {
 | |
| 		ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 	} else if (strncmp(cmd, "disablewqbat", strlen(cmd)) == 0) {
 | |
| 		ili_wq_ctrl(WQ_BAT, DISABLE);
 | |
| 	} else if (strncmp(cmd, "gesture", strlen(cmd)) == 0) {
 | |
| 		ilits->gesture = !ilits->gesture;
 | |
| 		ILI_INFO("gesture = %d\n", ilits->gesture);
 | |
| 	} else if (strncmp(cmd, "gestureon", strlen(cmd)) == 0) {
 | |
| 		ilits->gesture = ENABLE;
 | |
| 		ILI_INFO("gestureon = %d\n", ilits->gesture);
 | |
| 	} else if (strncmp(cmd, "gestureoff", strlen(cmd)) == 0) {
 | |
| 		ilits->gesture = DISABLE;
 | |
| 		ILI_INFO("gestureoff = %d\n", ilits->gesture);
 | |
| 	} else if (strncmp(cmd, "esdgesture", strlen(cmd)) == 0) {
 | |
| 		ilits->pll_clk_wakeup = true;
 | |
| 		if (ili_gesture_recovery() < 0) {
 | |
| 			ILI_ERR("Gesture recovery failed\n");
 | |
| 			size = -1;
 | |
| 		}
 | |
| 	} else if (strncmp(cmd, "esdspi", strlen(cmd)) == 0) {
 | |
| 		ili_spi_recovery();
 | |
| 	} else if (strncmp(cmd, "sleepin", strlen(cmd)) == 0) {
 | |
| 		ili_ic_func_ctrl("sleep", SLEEP_IN);
 | |
| 	} else if (strncmp(cmd, "deepsleepin", strlen(cmd)) == 0) {
 | |
| 		ili_ic_func_ctrl("sleep", DEEP_SLEEP_IN);
 | |
| 	} else if (strncmp(cmd, "iceflag", strlen(cmd)) == 0) {
 | |
| 		if (data[1] == ENABLE)
 | |
| 			atomic_set(&ilits->ice_stat, ENABLE);
 | |
| 		else
 | |
| 			atomic_set(&ilits->ice_stat, DISABLE);
 | |
| 		ILI_INFO("ice mode flag = %d\n", atomic_read(&ilits->ice_stat));
 | |
| 	} else if (strncmp(cmd, "gesturenormal", strlen(cmd)) == 0) {
 | |
| 		ilits->gesture_mode = DATA_FORMAT_GESTURE_NORMAL;
 | |
| 		ILI_INFO("gesture mode = %d\n", ilits->gesture_mode);
 | |
| 	} else if (strncmp(cmd, "gestureinfo", strlen(cmd)) == 0) {
 | |
| 		ilits->gesture_mode = DATA_FORMAT_GESTURE_INFO;
 | |
| 		ILI_INFO("gesture mode = %d\n", ilits->gesture_mode);
 | |
| 	} else if (strncmp(cmd, "switchtestmode", strlen(cmd)) == 0) {
 | |
| 		ili_switch_tp_mode(P5_X_FW_TEST_MODE);
 | |
| 	} else if (strncmp(cmd, "switchdebugmode", strlen(cmd)) == 0) {
 | |
| 		u8 data_type;
 | |
| 		data_type = data[1] & 0xFF;
 | |
| 		ili_set_tp_data_len(DATA_FORMAT_DEBUG, false, &data_type);
 | |
| 	} else if (strncmp(cmd, "switchdemomode", strlen(cmd)) == 0) {
 | |
| 		u8 data_type;
 | |
| 		data_type = data[1] & 0xFF;
 | |
| 		ili_set_tp_data_len(DATA_FORMAT_DEMO, false, &data_type);
 | |
| 	} else if (strncmp(cmd, "switchgesturedebugmode", strlen(cmd)) == 0) {
 | |
| 		u8 data_type;
 | |
| 		data_type = data[1] & 0xFF;
 | |
| 		ili_set_tp_data_len(DATA_FORMAT_GESTURE_DEBUG, false, &data_type);
 | |
| 	} else if (strncmp(cmd, "dbgflag", strlen(cmd)) == 0) {
 | |
| 		ilits->dnp = !ilits->dnp;
 | |
| 		ILI_INFO("debug flag message = %d\n", ilits->dnp);
 | |
| 	} else if (strncmp(cmd, "spiclk", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("spi clk num = %d\n", data[1]);
 | |
| 		ili_core_spi_setup(data[1]);
 | |
| 	} else if (strncmp(cmd, "ss", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("sense_stop = %d\n", data[1]);
 | |
| 		ilits->ss_ctrl = data[1];
 | |
| 	} else if (strncmp(cmd, "iow", strlen(cmd)) == 0) {
 | |
| 		int w_len = 0;
 | |
| 		w_len = data[1];
 | |
| 		ILI_INFO("w_len = %d\n", w_len);
 | |
| 		for (i = 0; i < w_len; i++) {
 | |
| 			temp[i] = data[2 + i];
 | |
| 			ILI_INFO("write[%d] = %x\n", i, temp[i]);
 | |
| 		}
 | |
| 
 | |
| 		ilits->wrapper(temp, w_len, NULL, 0, ON, OFF);
 | |
| 	} else if (strncmp(cmd, "ior", strlen(cmd)) == 0) {
 | |
| 		int r_len = 0;
 | |
| 		r_len = data[1];
 | |
| 		ILI_INFO("r_len = %d\n", r_len);
 | |
| 		ilits->wrapper(NULL, 0, temp, r_len, ON, OFF);
 | |
| 		for (i = 0; i < r_len; i++)
 | |
| 			ILI_INFO("read[%d] = %x\n", i, temp[i]);
 | |
| 	} else if (strncmp(cmd, "iowr", strlen(cmd)) == 0) {
 | |
| 		int delay = 0;
 | |
| 		int w_len = 0, r_len = 0;
 | |
| 		w_len = data[1];
 | |
| 		r_len = data[2];
 | |
| 		delay = data[3];
 | |
| 		ILI_INFO("w_len = %d, r_len = %d, delay = %d\n", w_len, r_len, delay);
 | |
| 
 | |
| 		for (i = 0; i < w_len; i++) {
 | |
| 			temp[i] = data[4 + i];
 | |
| 			ILI_INFO("write[%d] = %x\n", i, temp[i]);
 | |
| 		}
 | |
| 		ret = ilits->wrapper(temp, w_len, NULL, 0, OFF, OFF);
 | |
| 		memset(temp, 0, sizeof(temp));
 | |
| 		mdelay(delay);
 | |
| 		ilits->wrapper(NULL, 0, temp, r_len, OFF, OFF);
 | |
| 		for (i = 0; i < r_len; i++)
 | |
| 			ILI_INFO("read[%d] = %x\n", i, temp[i]);
 | |
| 	} else if (strcmp(cmd, "iowrint") == 0) {
 | |
| 		int delay = 0;
 | |
| 		int w_len = 0, r_len = 0;
 | |
| 		w_len = data[1];
 | |
| 		r_len = data[2];
 | |
| 		delay = data[3];
 | |
| 		ILI_INFO("w_len = %d, r_len = %d, delay = %d\n", w_len, r_len, delay);
 | |
| 		for (i = 0; i < w_len; i++) {
 | |
| 			temp[i] = data[4 + i];
 | |
| 			ILI_INFO("write[%d] = %x\n", i, temp[i]);
 | |
| 		}
 | |
| 		ret = ilits->wrapper(temp, w_len, temp, r_len, ON, ON);
 | |
| 		for (i = 0; i < r_len; i++)
 | |
| 			ILI_INFO("read[%d] = %x\n", i, temp[i]);
 | |
| 	} else if (strncmp(cmd, "getddiregdata", strlen(cmd)) == 0) {
 | |
| 		u8 ddi_data = 0;
 | |
| 		ILI_INFO("Get ddi reg one page: page = %x, reg = %x\n", data[1], data[2]);
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| 			ili_ic_get_cascade_ddi_reg_onepage(data[1], data[2], &ddi_data, OFF);
 | |
| 		} else {
 | |
| 			ili_ic_get_ddi_reg_onepage(data[1], data[2], &ddi_data, OFF);
 | |
| 		}
 | |
| 		ILI_INFO("ddi_data = %x\n", ddi_data);
 | |
| 	} else if (strncmp(cmd, "setddiregdata", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("Set ddi reg one page: page = %x, reg = %x, data = %x\n", data[1], data[2], data[3]);
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| 			ili_ic_set_cascade_ddi_reg_onepage(data[1], data[2], data[3], OFF);
 | |
| 		} else {
 | |
| 			ili_ic_set_ddi_reg_onepage(data[1], data[2], data[3], OFF);
 | |
| 		}
 | |
| 	} else if (strncmp(cmd, "dumpflashdata", strlen(cmd)) == 0) {
 | |
| 		ilits->fw_update_stat = FW_STAT_INIT;
 | |
| 		ILI_INFO("Start = 0x%x, End = 0x%x, Dump Hex path = %s\n", data[1], data[2], DUMP_FLASH_PATH);
 | |
| 		ret = ili_fw_dump_flash_data(data[1], data[2], false, OFF);
 | |
| 		ilits->fw_update_stat = (ret < 0) ? FW_UPDATE_FAIL : FW_UPDATE_PASS;
 | |
| 		ILI_INFO("ilits->fw_update_stat = %d\n", ilits->fw_update_stat);
 | |
| 	} else if (strncmp(cmd, "dumpiramdata", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("Start = 0x%x, End = 0x%x, Dump IRAM path = %s\n", data[1], data[2], DUMP_IRAM_PATH);
 | |
| 		ilits->fw_update_stat = FW_STAT_INIT;
 | |
| 		ret = ili_fw_dump_iram_data(data[1], data[2], true, OFF);
 | |
| 		ilits->fw_update_stat = (ret < 0) ? FW_UPDATE_FAIL : FW_UPDATE_PASS;
 | |
| 		ILI_INFO("ilits->fw_update_stat = %d\n", ilits->fw_update_stat);
 | |
| 	} else if (strncmp(cmd, "edge_palm_ctrl", strlen(cmd)) == 0) {
 | |
| 		ili_ic_func_ctrl("edge_palm", data[1]);
 | |
| 	} else if (strncmp(cmd, "uart_mode_ctrl", strlen(cmd)) == 0) {
 | |
| 		ili_fw_uart_ctrl(data[1]);
 | |
| 	} else if (strncmp(cmd, "flashesdgesture", strlen(cmd)) == 0) {
 | |
| 		ili_touch_esd_gesture_flash();
 | |
| 	} else if (strncmp(cmd, "intact", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("Set INT trigger = %x\n", data[1]);
 | |
| 		ili_ic_int_trigger_ctrl(data[1]);
 | |
| 	} else if (strncmp(cmd, "spiw", strlen(cmd)) == 0) {
 | |
| 		int wlen;
 | |
| 		wlen = data[1];
 | |
| 		temp[0] = 0x82;
 | |
| 		for (i = 0; i < wlen; i++) {
 | |
| 			temp[i] = data[2 + i];
 | |
| 			ILI_INFO("write[%d] = %x\n", i, temp[i]);
 | |
| 		}
 | |
| 		ilits->spi_write_then_read(ilits->spi, temp, wlen, NULL, 0);
 | |
| 	} else if (strncmp(cmd, "spir", strlen(cmd)) == 0) {
 | |
| 		int rlen;
 | |
| 		u8 *rbuf = NULL;
 | |
| 		rlen = data[1];
 | |
| 		rbuf = kzalloc(rlen, GFP_KERNEL | GFP_DMA);
 | |
| 		if (ERR_ALLOC_MEM(rbuf)) {
 | |
| 			ILI_ERR("Failed to allocate dma_rxbuf, %ld\n", PTR_ERR(rbuf));
 | |
| 			kfree(rbuf);
 | |
| 			goto out;
 | |
| 		}
 | |
| 		temp[0] = 0x83;
 | |
| 		ilits->spi_write_then_read(ilits->spi, temp, 1, rbuf, rlen);
 | |
| 		for (i = 0; i < rlen; i++)
 | |
| 			ILI_INFO("read[%d] = %x\n", i, rbuf[i]);
 | |
| 		kfree(rbuf);
 | |
| 	} else if (strncmp(cmd, "spirw", strlen(cmd)) == 0) {
 | |
| 		int wlen, rlen;
 | |
| 		u8 *rbuf = NULL;
 | |
| 		wlen = data[1];
 | |
| 		rlen = data[2];
 | |
| 		for (i = 0; i < wlen; i++) {
 | |
| 			temp[i] = data[3 + i];
 | |
| 			ILI_INFO("write[%d] = %x\n", i, temp[i]);
 | |
| 		}
 | |
| 		if (rlen != 0) {
 | |
| 			rbuf = kzalloc(rlen, GFP_KERNEL | GFP_DMA);
 | |
| 			if (ERR_ALLOC_MEM(rbuf)) {
 | |
| 				ILI_ERR("Failed to allocate dma_rxbuf, %ld\n", PTR_ERR(rbuf));
 | |
| 				kfree(rbuf);
 | |
| 				goto out;
 | |
| 			}
 | |
| 		}
 | |
| 		ilits->spi_write_then_read(ilits->spi, temp, wlen, rbuf, rlen);
 | |
| 		if (rlen != 0) {
 | |
| 			for (i = 0; i < rlen; i++)
 | |
| 				ILI_INFO("read[%d] = %x\n", i, rbuf[i]);
 | |
| 		}
 | |
| 		kfree(rbuf);
 | |
| 	} else if (strncmp(cmd, "ges_sym", strlen(cmd)) == 0) {
 | |
| 		struct gesture_symbol *ptr_sym = &ilits->ges_sym;
 | |
| 		u8 *ptr;
 | |
| 		ptr = (u8 *) ptr_sym;
 | |
| 		ptr[0] = data[1];
 | |
| 		ptr[1] = data[2];
 | |
| 		ptr[2] = data[3];
 | |
| 		ili_dump_data(ptr, 8, 3, 0, "Gesture symbol");
 | |
| 	} else if (strncmp(cmd, "mode", strlen(cmd)) == 0) {
 | |
| 		temp[0] = data[1];
 | |
| 		temp[1] = data[2];
 | |
| 		temp[2] = data[3];
 | |
| 		temp[3] = data[4];
 | |
| 		temp[4] = data[5];
 | |
|         temp[5] = data[6];
 | |
| 		ret = ili_tp_data_mode_ctrl(temp);
 | |
| 	} else if (strncmp(cmd, "switchmpretry", strlen(cmd)) == 0) {
 | |
| 		ilits->mp_retry = !ilits->mp_retry;
 | |
| 		ILI_INFO("switchmpretry = %d\n", ilits->mp_retry);
 | |
| 	} else if (strncmp(cmd, "edgepalmpara", strlen(cmd)) == 0) {
 | |
| 		ilits->edge_palm_para[0] = P5_X_EDGE_PLAM_CTRL_1;
 | |
| 		ilits->edge_palm_para[1] = P5_X_EDGE_PALM_TUNING_PARA;
 | |
| 		for (i = 0; i < 14; i++) {
 | |
| 			ilits->edge_palm_para[i * 2 + 2] = (data[i + 1] & 0xFF00) >> 8;
 | |
| 			ilits->edge_palm_para[i * 2 + 3] = data[i + 1] & 0xFF;
 | |
| 		}
 | |
| 		ilits->edge_palm_para[30] = ili_calc_packet_checksum(ilits->edge_palm_para
 | |
| 			, P5_X_EDGE_PALM_PARA_LENGTH - 1);
 | |
| 
 | |
| 		for (i = 0; i < P5_X_EDGE_PALM_PARA_LENGTH; i++) {
 | |
| 			ILI_INFO("edge_palm_para[%d] = 0x%2x\n", i, ilits->edge_palm_para[i]);
 | |
| 		}
 | |
| 
 | |
| 		ili_ic_send_edge_palm_para();
 | |
| #ifdef ROI
 | |
| 	} else if (strncmp(cmd, "knuckle", strlen(cmd)) == 0) {
 | |
| 		ilits->knuckle = !ilits->knuckle;
 | |
| 		if (ilits->knuckle == true) {
 | |
| 			ili_config_knuckle_roi_ctrl(CMD_ENABLE);
 | |
| 		} else {
 | |
| 			ili_config_knuckle_roi_ctrl(CMD_DISABLE);
 | |
| 		}
 | |
| 		ILI_INFO("knuckle = %s\n", ilits->knuckle ? "ENABLE" : "DISABLE");
 | |
| #endif
 | |
| 	} else if (strncmp(cmd, "proxfacemode", strlen(cmd)) == 0) {
 | |
| 		ilits->proxmity_face = false;
 | |
| 		ilits->prox_face_mode = data[1] & 0xFF;
 | |
| 		if (data[1] != 0x00) {
 | |
| 			if (ilits->prox_face_mode == PROXIMITY_BACKLIGHT) {
 | |
| 				data[1] = 0x01;
 | |
| 			}
 | |
| 			if (ili_ic_func_ctrl("proximity", data[1]) < 0) {
 | |
| 				ILI_ERR("Write proximity cmd failed\n");
 | |
| 			}
 | |
| 		} else {
 | |
| 			if (ili_ic_func_ctrl("proximity", 0x00) < 0) {
 | |
| 				ILI_ERR("Write proximity cmd failed\n");
 | |
| 			}
 | |
| 		}
 | |
| 		ilits->power_status = true;
 | |
| 		ILI_INFO("switch proximity face mode = %d, level = %d\n", ilits->prox_face_mode, data[1]);
 | |
| 	} else if (strncmp(cmd, "mp_lcm_off_env", strlen(cmd)) == 0) {
 | |
| 		ili_mp_lcm_off_env_ctrl(data[1]);
 | |
| 	} else if (strncmp(cmd, "releasetouch", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("ioctl: release all touch\n");
 | |
| 		ili_touch_release_all_point();
 | |
| 	} else if (strncmp(cmd, "releasepen", strlen(cmd)) == 0) {
 | |
| 		ILI_INFO("ioctl: release pen\n");
 | |
| 		ili_pen_release();
 | |
| 	} else {
 | |
| 		ILI_ERR("Unknown command\n");
 | |
| 		size = -1;
 | |
| 	}
 | |
| out:
 | |
| 	ipio_kfree((void **)&data);
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return size;
 | |
| }
 | |
| 
 | |
| #ifdef CONFIG_COMPAT
 | |
| static long ilitek_node_compat_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
 | |
| {
 | |
| 	long ret = 0;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (!filp->f_op || !filp->f_op->unlocked_ioctl) {
 | |
| 		ILI_ERR("There's no unlocked_ioctl defined in file\n");
 | |
| 		return -ENOTTY;
 | |
| 	}
 | |
| 
 | |
| 	ILI_DBG("cmd = %d\n", _IOC_NR(cmd));
 | |
| 
 | |
| 	switch (cmd) {
 | |
| 	case ILITEK_COMPAT_IOCTL_I2C_WRITE_DATA:
 | |
| 		ILI_DBG("compat_ioctl: convert i2c/spi write\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_I2C_WRITE_DATA, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_I2C_READ_DATA:
 | |
| 		ILI_DBG("compat_ioctl: convert i2c/spi read\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_I2C_READ_DATA, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_I2C_SET_WRITE_LENGTH:
 | |
| 		ILI_DBG("compat_ioctl: convert set write length\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_I2C_SET_WRITE_LENGTH, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_I2C_SET_READ_LENGTH:
 | |
| 		ILI_DBG("compat_ioctl: convert set read length\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_I2C_SET_READ_LENGTH, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_HW_RESET:
 | |
| 		ILI_DBG("compat_ioctl: convert hw reset\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_HW_RESET, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_POWER_SWITCH:
 | |
| 		ILI_DBG("compat_ioctl: convert power switch\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_POWER_SWITCH, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_REPORT_SWITCH:
 | |
| 		ILI_DBG("compat_ioctl: convert report switch\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_REPORT_SWITCH, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_IRQ_SWITCH:
 | |
| 		ILI_DBG("compat_ioctl: convert irq switch\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_IRQ_SWITCH, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_DEBUG_LEVEL:
 | |
| 		ILI_DBG("compat_ioctl: convert debug level\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_DEBUG_LEVEL, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_FUNC_MODE:
 | |
| 		ILI_DBG("compat_ioctl: convert format mode\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_FUNC_MODE, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_FW_VER:
 | |
| 		ILI_DBG("compat_ioctl: convert set read length\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_FW_VER, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_PL_VER:
 | |
| 		ILI_DBG("compat_ioctl: convert fw version\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_PL_VER, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_CORE_VER:
 | |
| 		ILI_DBG("compat_ioctl: convert core version\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_CORE_VER, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_DRV_VER:
 | |
| 		ILI_DBG("compat_ioctl: convert driver version\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_DRV_VER, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_CHIP_ID:
 | |
| 		ILI_DBG("compat_ioctl: convert chip id\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_CHIP_ID, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_MODE_CTRL:
 | |
| 		ILI_DBG("compat_ioctl: convert tp mode ctrl\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_MODE_CTRL, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_MODE_STATUS:
 | |
| 		ILI_DBG("compat_ioctl: convert tp mode status\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_MODE_STATUS, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_ICE_MODE_SWITCH:
 | |
| 		ILI_DBG("compat_ioctl: convert tp mode switch\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_ICE_MODE_SWITCH, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_INTERFACE_TYPE:
 | |
| 		ILI_DBG("compat_ioctl: convert interface type\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_INTERFACE_TYPE, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_DUMP_FLASH:
 | |
| 		ILI_DBG("compat_ioctl: convert dump flash\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_DUMP_FLASH, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_FW_UART_CTRL:
 | |
| 		ILI_DBG("compat_ioctl: convert fw uart\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_FW_UART_CTRL, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_PANEL_INFO:
 | |
| 		ILI_DBG("compat_ioctl: convert resolution\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_PANEL_INFO, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_TP_INFO:
 | |
| 		ILI_DBG("compat_ioctl: convert tp info\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_TP_INFO, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_WRAPPER_RW:
 | |
| 		ILI_DBG("compat_ioctl: convert wrapper\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_WRAPPER_RW, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_DDI_WRITE:
 | |
| 		ILI_DBG("compat_ioctl: convert ddi write\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_DDI_WRITE, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_DDI_READ:
 | |
| 		ILI_DBG("compat_ioctl: convert ddi read\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_DDI_READ, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_REPORT_RATE_SET:
 | |
| 		ILI_DBG("compat_ioctl: convert report rate set\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_REPORT_RATE_SET, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_MP_LCM_OFF_ENV:
 | |
| 		ILI_DBG("compat_ioctl: mp lcm env\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_MP_LCM_OFF_ENV, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_RELEASE_TOUCH:
 | |
| 		ILI_DBG("compat_ioctl: release touch\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_RELEASE_TOUCH, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_LCM_STATUS:
 | |
| 		ILI_DBG("compat_ioctl: lcm status\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_LCM_STATUS, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_SLAVE_CTRL:
 | |
| 		ILI_DBG("compat_ioctl: lcm status\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_SLAVE_CTRL, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_CASCADE_REG_RW:
 | |
| 		ILI_DBG("compat_ioctl: lcm status\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_CASCADE_REG_RW, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_INTERFACE_GET:
 | |
| 		ILI_DBG("compat_ioctl: get interface\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_INTERFACE_GET, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	case ILITEK_COMPAT_IOCTL_ICE_MODE_FLAG_SET:
 | |
| 		ILI_DBG("compat_ioctl: ice mode flag set\n");
 | |
| 		ret = filp->f_op->unlocked_ioctl(filp, ILITEK_IOCTL_ICE_MODE_FLAG_SET, (unsigned long)compat_ptr(arg));
 | |
| 		return ret;
 | |
| 	default:
 | |
| 		ILI_ERR("no ioctl cmd, return ilitek_node_ioctl\n");
 | |
| 		return -ENOIOCTLCMD;
 | |
| 	}
 | |
| }
 | |
| #endif
 | |
| 
 | |
| static long ilitek_node_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)
 | |
| {
 | |
| 	int ret = 0, length = 0;
 | |
| 	u8 *szBuf = NULL, if_to_user = 0;
 | |
| 	static u16 i2c_rw_length;
 | |
| 	u32 id_to_user[64] = {0};
 | |
| 	bool esd_en = ilits->wq_esd_ctrl, bat_en = ilits->wq_bat_ctrl;
 | |
| 	u8 *wrap_rbuf = NULL, wrap_int = 0;
 | |
| 	u16 wrap_wlen = 0, wrap_rlen = 0;
 | |
| 	bool spi_irq, i2c_irq;
 | |
| 	bool read = 0;
 | |
| 	u32 type, addr, read_data, write_data, write_len;
 | |
| 
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	if (_IOC_TYPE(cmd) != ILITEK_IOCTL_MAGIC) {
 | |
| 		ILI_ERR("The Magic number doesn't match\n");
 | |
| 		return -ENOTTY;
 | |
| 	}
 | |
| 
 | |
| 	if (_IOC_NR(cmd) > ILITEK_IOCTL_MAXNR) {
 | |
| 		ILI_ERR("The number of ioctl doesn't match\n");
 | |
| 		return -ENOTTY;
 | |
| 	}
 | |
| 
 | |
| 	ILI_DBG("cmd = %d\n", _IOC_NR(cmd));
 | |
| 
 | |
| 	mutex_lock(&ilits->touch_mutex);
 | |
| 
 | |
| 	szBuf = kcalloc(IOCTL_I2C_BUFF, sizeof(u8), GFP_KERNEL);
 | |
| 	if (ERR_ALLOC_MEM(szBuf)) {
 | |
| 		ILI_ERR("Failed to allocate mem\n");
 | |
| 		ret = -ENOMEM;
 | |
| 		goto out;
 | |
| 	}
 | |
| 
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, DISABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, DISABLE);
 | |
| 
 | |
| 	switch (cmd) {
 | |
| 	case ILITEK_IOCTL_I2C_WRITE_DATA:
 | |
| 		ILI_DBG("ioctl: write len = %d\n", i2c_rw_length);
 | |
| 
 | |
| 		if (i2c_rw_length > IOCTL_I2C_BUFF) {
 | |
| 			ILI_ERR("ERROR! write len is largn than ioctl buf (%d, %ld)\n",
 | |
| 					i2c_rw_length, IOCTL_I2C_BUFF);
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, i2c_rw_length)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		ret = ilits->wrapper(szBuf, i2c_rw_length, NULL, 0, OFF, OFF);
 | |
| 		if (ret < 0)
 | |
| 			ILI_ERR("Failed to write data\n");
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_I2C_READ_DATA:
 | |
| 		ILI_DBG("ioctl: read len = %d\n", i2c_rw_length);
 | |
| 
 | |
| 		if (i2c_rw_length > IOCTL_I2C_BUFF) {
 | |
| 			ILI_ERR("ERROR! read len is largn than ioctl buf (%d, %ld)\n",
 | |
| 					i2c_rw_length, IOCTL_I2C_BUFF);
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		ret = ilits->wrapper(NULL, 0, szBuf, i2c_rw_length, OFF, OFF);
 | |
| 		if (ret < 0) {
 | |
| 			ILI_ERR("Failed to read data\n");
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		if (copy_to_user((u8 *) arg, szBuf, i2c_rw_length)) {
 | |
| 			ILI_ERR("Failed to copy data to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_I2C_SET_WRITE_LENGTH:
 | |
| 	case ILITEK_IOCTL_I2C_SET_READ_LENGTH:
 | |
| 		i2c_rw_length = arg;
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_HW_RESET:
 | |
| 		ILI_DBG("ioctl: hw reset\n");
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| 			ili_wdt_reset_status(true, false);
 | |
| 		}
 | |
| 		ili_reset_ctrl(ilits->reset);
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_POWER_SWITCH:
 | |
| 		ILI_INFO("Not implemented yet\n");
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_REPORT_SWITCH:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 1)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		ILI_DBG("ioctl: report switch = %d\n", szBuf[0]);
 | |
| 		if (szBuf[0]) {
 | |
| 			ilits->report = ENABLE;
 | |
| 			ILI_DBG("report is enabled\n");
 | |
| 		} else {
 | |
| 			ilits->report = DISABLE;
 | |
| 			ILI_DBG("report is disabled\n");
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_IRQ_SWITCH:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 1)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 		ILI_DBG("ioctl: irq switch = %d\n", szBuf[0]);
 | |
| 		if (szBuf[0])
 | |
| 			ili_irq_enable();
 | |
| 		else
 | |
| 			ili_irq_disable();
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_DEBUG_LEVEL:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, sizeof(u32))) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		debug_en = !debug_en;
 | |
| 		ILI_DBG("debug_en = %d", debug_en);
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_FUNC_MODE:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 3)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		ILI_DBG("ioctl: set func mode = %x,%x,%x\n", szBuf[0], szBuf[1], szBuf[2]);
 | |
| 		ret = ilits->wrapper(szBuf, 3, NULL, 0, ON, OFF);
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_FW_VER:
 | |
| 		ILI_DBG("ioctl: get fw and mp version\n");
 | |
| 		szBuf[7] = ilits->chip->fw_mp_ver & 0xFF;
 | |
| 		szBuf[6] = (ilits->chip->fw_mp_ver >> 8) & 0xFF;
 | |
| 		szBuf[5] = (ilits->chip->fw_mp_ver >> 16) & 0xFF;
 | |
| 		szBuf[4] = ilits->chip->fw_mp_ver >> 24;
 | |
| 		szBuf[3] = ilits->chip->fw_ver & 0xFF;
 | |
| 		szBuf[2] = (ilits->chip->fw_ver >> 8) & 0xFF;
 | |
| 		szBuf[1] = (ilits->chip->fw_ver >> 16) & 0xFF;
 | |
| 		szBuf[0] = ilits->chip->fw_ver >> 24;
 | |
| 		ILI_DBG("Firmware version = %d.%d.%d.%d\n", szBuf[0], szBuf[1], szBuf[2], szBuf[3]);
 | |
| 		ILI_DBG("Firmware MP version = %d.%d.%d.%d\n", szBuf[4], szBuf[5], szBuf[6], szBuf[7]);
 | |
| 
 | |
| 		if (copy_to_user((u8 *) arg, szBuf, 8)) {
 | |
| 			ILI_ERR("Failed to copy data to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_PL_VER:
 | |
| 		ILI_DBG("ioctl: get protocl version\n");
 | |
| 		szBuf[2] = ilits->protocol->ver & 0xFF;
 | |
| 		szBuf[1] = (ilits->protocol->ver >> 8) & 0xFF;
 | |
| 		szBuf[0] = ilits->protocol->ver >> 16;
 | |
| 		ILI_DBG("Protocol version = %d.%d.%d\n", szBuf[0], szBuf[1], szBuf[2]);
 | |
| 
 | |
| 		if (copy_to_user((u8 *) arg, szBuf, 3)) {
 | |
| 			ILI_ERR("Failed to copy data to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_CORE_VER:
 | |
| 		ILI_DBG("ioctl: get core version\n");
 | |
| 		if (ilits->protocol->core_ver_len == P5_X_CORE_VER_THREE_LENGTH)
 | |
| 			szBuf[3] = 0xFF;
 | |
| 		else
 | |
| 			szBuf[3] = ilits->chip->core_ver & 0xFF;
 | |
| 		szBuf[2] = (ilits->chip->core_ver >> 8) & 0xFF;
 | |
| 		szBuf[1] = (ilits->chip->core_ver >> 16) & 0xFF;
 | |
| 		szBuf[0] = ilits->chip->core_ver >> 24;
 | |
| 		ILI_DBG("Core version = %d.%d.%d.%d, length = %d\n",
 | |
| 			szBuf[0], szBuf[1], szBuf[2], szBuf[3], ilits->protocol->core_ver_len);
 | |
| 
 | |
| 		if (copy_to_user((u8 *) arg, szBuf, 4)) {
 | |
| 			ILI_ERR("Failed to copy data to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_DRV_VER:
 | |
| 		ILI_DBG("ioctl: get driver version\n");
 | |
| 		length = snprintf(szBuf, USER_STR_BUFF * sizeof(unsigned char), "%s", DRIVER_VERSION);
 | |
| 
 | |
| 		if (copy_to_user((u8 *) arg, szBuf, length)) {
 | |
| 			ILI_ERR("Failed to copy driver ver to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_CHIP_ID:
 | |
| 		ILI_DBG("ioctl: get chip id (with second chip id)\n");
 | |
| 		id_to_user[0] = 0x78787878;
 | |
| 		id_to_user[1] = ilits->chip->pid;
 | |
| 		id_to_user[2] = ilits->chip->second_pid;
 | |
| 		id_to_user[3] = ilits->chip->otp_id;
 | |
| 		id_to_user[4] = ilits->chip->ana_id;
 | |
| 		length = 5;
 | |
| 
 | |
| 		if (copy_to_user((u32 *) arg, id_to_user, sizeof(u32) * length)) {
 | |
| 			ILI_ERR("Failed to copy driver ver to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_MODE_CTRL:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 10)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 		ILI_DBG("ioctl: switch fw format = %d\n", szBuf[0]);
 | |
| 		ret = ili_tp_data_mode_ctrl(szBuf);
 | |
| 
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_MODE_STATUS:
 | |
| 		ILI_DBG("ioctl: current firmware mode = %d", ilits->tp_data_mode);
 | |
| 		if (copy_to_user((int *)arg, &ilits->tp_data_mode, sizeof(int))) {
 | |
| 			ILI_ERR("Failed to copy driver ver to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	/* It works for host downloado only */
 | |
| 	case ILITEK_IOCTL_ICE_MODE_SWITCH:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 3)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		ILI_DBG("ioctl: switch ice mode = %d, mcu on = %d\n", szBuf[0], szBuf[1]);
 | |
| 
 | |
| 		if (ilits->cascade_info_block.nNum != 0) {
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 			if (szBuf[2] == 0) {
 | |
| 				/* for wifi daemon flow */
 | |
| 				atomic_set(&ilits->ice_stat, (szBuf[0] == ENABLE) ? DISABLE : ENABLE);
 | |
| 
 | |
| 				ili_ice_mode_ctrl_by_mode(szBuf[0] ? ENABLE : DISABLE,
 | |
| 					szBuf[1] ? ENABLE : DISABLE, ilits->slave_wr_ctrl);
 | |
| 			} else {
 | |
| 				ILI_DBG("ioctl: mode = %d\n", szBuf[2]);
 | |
| 
 | |
| 				ili_ice_mode_ctrl_by_mode(szBuf[0] ? ENABLE : DISABLE,
 | |
| 					szBuf[1] ? ENABLE : DISABLE, szBuf[2]);
 | |
| 			}
 | |
| #elif (TDDI_INTERFACE == BUS_SPI)
 | |
| 			if (ilits->slave_wr_ctrl == ENABLE && szBuf[0] == ENABLE) {
 | |
| 				ilits->ice_mode_ctrl(ENABLE, szBuf[1], BOTH);
 | |
| 			}
 | |
| 
 | |
| 			/* for wifi daemon flow */
 | |
| 			if (szBuf[0] == ENABLE)
 | |
| 				atomic_set(&ilits->ice_stat, DISABLE);
 | |
| 
 | |
| 			if (ili_ice_mode_ctrl(szBuf[0] ? ENABLE : DISABLE,
 | |
| 				szBuf[1] ? ENABLE : DISABLE) < 0)
 | |
| 				ILI_ERR("ioctl: set ice mode failed\n");
 | |
| #endif
 | |
| 		} else {
 | |
| 			if (ili_ice_mode_ctrl(szBuf[0] ? ENABLE : DISABLE,
 | |
| 				szBuf[1] ? ENABLE : DISABLE) < 0)
 | |
| 				ILI_ERR("ioctl: set ice mode failed\n");
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_INTERFACE_TYPE:
 | |
| 		if_to_user = ilits->hwif->bus_type;
 | |
| 		if (copy_to_user((u8 *) arg, &if_to_user, sizeof(if_to_user))) {
 | |
| 			ILI_ERR("Failed to copy driver ver to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_DUMP_FLASH:
 | |
| 		ILI_DBG("ioctl: dump flash data\n");
 | |
| 		ret = ili_fw_dump_flash_data(0, 0, true, OFF);
 | |
| 		if (ret < 0) {
 | |
| 			ILI_ERR("ioctl: Failed to dump flash data\n");
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_FW_UART_CTRL:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 1)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 		ILI_DBG("ioctl: fw UART  = %d\n", szBuf[0]);
 | |
| 
 | |
| 		ili_fw_uart_ctrl(szBuf[0]);
 | |
| 
 | |
| 		if_to_user = szBuf[0];
 | |
| 
 | |
| 		if (copy_to_user((u8 *) arg, &if_to_user, sizeof(if_to_user))) {
 | |
| 			ILI_ERR("Failed to copy driver ver to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_PANEL_INFO:
 | |
| 		ILI_DBG("ioctl: get panel resolution\n");
 | |
| 		id_to_user[0] = ilits->panel_wid;
 | |
| 		id_to_user[1] = ilits->panel_hei;
 | |
| 		id_to_user[2] = (ilits->trans_xy) ? 0x1 : 0x0;
 | |
| 
 | |
| 		if (copy_to_user((u32 *) arg, id_to_user, sizeof(u32) * 3)) {
 | |
| 			ILI_ERR("Failed to copy driver ver to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_TP_INFO:
 | |
| 		ILI_DBG("ioctl: get tp info\n");
 | |
| 		id_to_user[0] = ilits->min_x;
 | |
| 		id_to_user[1] = ilits->min_y;
 | |
| 		id_to_user[2] = ilits->max_x;
 | |
| 		id_to_user[3] = ilits->max_y;
 | |
| 		id_to_user[4] = ilits->xch_num;
 | |
| 		id_to_user[5] = ilits->ych_num;
 | |
| 		id_to_user[6] = ilits->stx;
 | |
| 		id_to_user[7] = ilits->srx;
 | |
| 
 | |
| 		if (copy_to_user((u32 *) arg, id_to_user, sizeof(u32) * 8)) {
 | |
| 			ILI_ERR("Failed to copy driver ver to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_WRAPPER_RW:
 | |
| 		ILI_DBG("ioctl: wrapper rw\n");
 | |
| 
 | |
| 		if (i2c_rw_length > IOCTL_I2C_BUFF || i2c_rw_length == 0) {
 | |
| 			ILI_ERR("ERROR! i2c_rw_length is is invalid\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, i2c_rw_length)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		wrap_int = szBuf[0];
 | |
| 		wrap_rlen = (szBuf[1] << 8) | szBuf[2];
 | |
| 		wrap_wlen = (szBuf[3] << 8) | szBuf[4];
 | |
| 
 | |
| 		ILI_DBG("wrap_int = %d\n", wrap_int);
 | |
| 		ILI_DBG("wrap_rlen = %d\n", wrap_rlen);
 | |
| 		ILI_DBG("wrap_wlen = %d\n", wrap_wlen);
 | |
| 
 | |
| 		if (wrap_wlen > IOCTL_I2C_BUFF || wrap_rlen > IOCTL_I2C_BUFF) {
 | |
| 			ILI_ERR("ERROR! R/W len is largn than ioctl buf\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		if (wrap_rlen > 0) {
 | |
| 			wrap_rbuf = kcalloc(IOCTL_I2C_BUFF, sizeof(u8), GFP_KERNEL);
 | |
| 			if (ERR_ALLOC_MEM(wrap_rbuf)) {
 | |
| 				ILI_ERR("Failed to allocate mem\n");
 | |
| 				ret = -ENOMEM;
 | |
| 				break;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if (wrap_int == 1) {
 | |
| 			i2c_irq = ON;
 | |
| 			spi_irq = ON;
 | |
| 		} else if (wrap_int == 2) {
 | |
| 			i2c_irq = OFF;
 | |
| 			spi_irq = OFF;
 | |
| 		} else {
 | |
| 			i2c_irq = OFF;
 | |
| 			spi_irq = (wrap_rlen > 0 ? ON : OFF);
 | |
| 		}
 | |
| 
 | |
| 		ILI_DBG("i2c_irq = %d, spi_irq = %d\n", i2c_irq, spi_irq);
 | |
| 
 | |
| 		ilits->wrapper(szBuf + 5, wrap_wlen, wrap_rbuf, wrap_rlen, spi_irq, i2c_irq);
 | |
| 
 | |
| 		ili_dump_data(szBuf + 5, 8, wrap_wlen, 16, "wrap_wbuf:");
 | |
| 		ili_dump_data(wrap_rbuf, 8, wrap_rlen, 16, "wrap_rbuf:");
 | |
| 		if (copy_to_user((u8 *) arg, wrap_rbuf, wrap_rlen)) {
 | |
| 			ILI_ERR("Failed to copy driver ver to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_DDI_WRITE:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 3)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 		ILI_DBG("ioctl: page = %x, reg = %x, data = %x\n", szBuf[0], szBuf[1], szBuf[2]);
 | |
| 		ili_ic_set_ddi_reg_onepage(szBuf[0], szBuf[1], szBuf[2], OFF);
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_DDI_READ:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 2)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 		ILI_DBG("ioctl: page = %x, reg = %x\n", szBuf[0], szBuf[1]);
 | |
| 		ili_ic_get_ddi_reg_onepage(szBuf[0], szBuf[1], &szBuf[2], OFF);
 | |
| 		ILI_DBG("ioctl: data = %x\n", szBuf[2]);
 | |
| 		if (copy_to_user((u8 *) arg, szBuf + 2, 1)) {
 | |
| 			ILI_ERR("Failed to copy data to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_REPORT_RATE_SET:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 2)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 		ILI_INFO("ioctl: set report rate mode = %x\n", szBuf[0]);
 | |
| 		if (ili_ic_report_rate_set(szBuf[0]) < 0) {
 | |
| 			ILI_ERR("Failed to set report rate\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_REPORT_RATE_GET:
 | |
| 
 | |
| 		szBuf[0] = ili_ic_report_rate_get();
 | |
| 		if (copy_to_user((u8 *) arg, szBuf, 1)) {
 | |
| 			ILI_ERR("Failed to copy data to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_MP_LCM_OFF_ENV:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 1)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 		ili_mp_lcm_off_env_ctrl(szBuf[0]);
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_RELEASE_TOUCH:
 | |
| 		ILI_INFO("ioctl: release all touch\n");
 | |
| 		ili_touch_release_all_point();
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_RELEASE_PEN:
 | |
| 		ILI_INFO("ioctl: release pen\n");
 | |
| 		ili_pen_release();
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_LCM_STATUS:
 | |
| 		ILI_INFO("ioctl: lcm status is %d\n", ilits->power_status);
 | |
| 		szBuf[0] = ilits->power_status;
 | |
| 		if (copy_to_user((u8 *) arg, szBuf, 1)) {
 | |
| 			ILI_ERR("Failed to copy data to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_SLAVE_CTRL:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 1)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		ilits->slave_wr_ctrl = (szBuf[0] == ENABLE) ? ENABLE : DISABLE;
 | |
| 		ILI_DBG(" %s slave write read ctrl = %x\n", ilits->slave_wr_ctrl ? "Enable" : "Disable", ilits->slave_wr_ctrl);
 | |
| #if (TDDI_INTERFACE == BUS_I2C && ENABLE_CASCADE)
 | |
| 		ilits->i2c_addr_change = (ilits->slave_wr_ctrl == SLAVE) ? SLAVE : MASTER;
 | |
| #endif
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_CASCADE_REG_RW:
 | |
| 		ILI_DBG("ioctl: cascade register rw\n");
 | |
| 
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, i2c_rw_length)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		type = szBuf[0];
 | |
| 		addr = (szBuf[1] << 24) + (szBuf[2] << 16) + (szBuf[3] << 8) + (szBuf[4]);
 | |
| 		write_data = (szBuf[5] << 24) + (szBuf[6] << 16) + (szBuf[7] << 8) + (szBuf[8]);
 | |
| 		write_len = szBuf[9];
 | |
| 
 | |
| 		ILI_DBG("type = %d\n", type);
 | |
| 		ILI_DBG("addr = 0x%X\n", addr);
 | |
| 		ILI_DBG("write_data = %X\n", write_data);
 | |
| 		ILI_DBG("write_len = %d\n", write_len);
 | |
| 
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 		if (type == read) {
 | |
| 			ili_ice_mode_read_by_mode(addr, &read_data, sizeof(u32), ilits->slave_wr_ctrl);
 | |
| 
 | |
| 			szBuf[0] = (read_data >> 24) & 0xFF;
 | |
| 			szBuf[1] = (read_data >> 16) & 0xFF;
 | |
| 			szBuf[2] = (read_data >> 8) & 0xFF;
 | |
| 			szBuf[3] = read_data & 0xFF;
 | |
| 			if (copy_to_user((u8 *) arg, szBuf, 4)) {
 | |
| 				ILI_ERR("Failed to copy data to user space\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		} else {
 | |
| 			ili_ice_mode_write_by_mode(addr, write_data, write_len, ilits->slave_wr_ctrl);
 | |
| 		}
 | |
| #else
 | |
| 		if (type == read) {
 | |
| 			if (ilits->slave_wr_ctrl == SLAVE) {
 | |
| 				ili_spi_ice_mode_read(addr, &read_data, sizeof(u32), SLAVE);
 | |
| 				ili_ice_mode_write_by_mode(MSPI_REG, 0x00, 1, BOTH);
 | |
| 			} else {
 | |
| 				if (ili_ice_mode_read_by_mode(addr, &read_data, sizeof(u32), MASTER) < 0) {
 | |
| 					ILI_ERR("Read data error\n");
 | |
| 				}
 | |
| 			}
 | |
| 			ILI_INFO("[READ]:addr = 0x%06x, read = 0x%08x\n", addr, read_data);
 | |
| 			szBuf[0] = (read_data >> 24) & 0xFF;
 | |
| 			szBuf[1] = (read_data >> 16) & 0xFF;
 | |
| 			szBuf[2] = (read_data >> 8) & 0xFF;
 | |
| 			szBuf[3] = read_data & 0xFF;
 | |
| 			if (copy_to_user((u8 *) arg, szBuf, 4)) {
 | |
| 				ILI_ERR("Failed to copy data to user space\n");
 | |
| 				ret = -ENOTTY;
 | |
| 			}
 | |
| 		} else {
 | |
| 			if (ilits->slave_wr_ctrl == SLAVE) {
 | |
| #if ENABLE_SPICASCADE_V2
 | |
| 				ili_ice_slave_write_register(addr, write_data, write_len);
 | |
| #else
 | |
| 				ili_mspi_write_slave_register(addr, write_data, write_len);
 | |
| #endif
 | |
| 				ili_ice_mode_write_by_mode(MSPI_REG, 0x00, 1, BOTH);
 | |
| 			} else {
 | |
| 				if (ili_ice_mode_write_by_mode(addr, write_data, write_len, MASTER) < 0) {
 | |
| 					ILI_ERR("Write data error\n");
 | |
| 				}
 | |
| 			}
 | |
| 			ILI_INFO("[WRITE]:addr = 0x%06x, write = 0x%08x, len = %d byte\n", addr, write_data, write_len);
 | |
| 		}
 | |
| 
 | |
| 		break;
 | |
| #endif
 | |
| 	case ILITEK_IOCTL_INTERFACE_GET:
 | |
| #if (TDDI_INTERFACE == BUS_I2C)
 | |
| 		szBuf[0] = 0x0;
 | |
| #else
 | |
| 		szBuf[0] = 0x1;
 | |
| #endif
 | |
| 		ILI_INFO("ioctl: get interface is %d\n", szBuf[0]);
 | |
| 		if (copy_to_user((u8 *) arg, szBuf, 1)) {
 | |
| 			ILI_ERR("Failed to copy data to user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 		}
 | |
| 		break;
 | |
| 	case ILITEK_IOCTL_ICE_MODE_FLAG_SET:
 | |
| 		if (copy_from_user(szBuf, (u8 *) arg, 1)) {
 | |
| 			ILI_ERR("Failed to copy data from user space\n");
 | |
| 			ret = -ENOTTY;
 | |
| 			break;
 | |
| 		}
 | |
| 
 | |
| 		ILI_DBG("ioctl: set ice mode flag  = %d\n", szBuf[0]);
 | |
| 
 | |
| 		if (szBuf[0] ? ENABLE : DISABLE) {
 | |
| 			atomic_set(&ilits->ice_stat, ENABLE);
 | |
| 			ilits->pll_clk_wakeup = false;
 | |
| 		} else {
 | |
| 			atomic_set(&ilits->ice_stat, DISABLE);
 | |
| 			ilits->pll_clk_wakeup = true;
 | |
| 		}
 | |
| 	default:
 | |
| 		ret = -ENOTTY;
 | |
| 		break;
 | |
| 	}
 | |
| 
 | |
| 	ipio_kfree((void **)&szBuf);
 | |
| 	ipio_kfree((void **)&wrap_rbuf);
 | |
| 
 | |
| out:
 | |
| 	if (esd_en)
 | |
| 		ili_wq_ctrl(WQ_ESD, ENABLE);
 | |
| 	if (bat_en)
 | |
| 		ili_wq_ctrl(WQ_BAT, ENABLE);
 | |
| 
 | |
| 	mutex_unlock(&ilits->touch_mutex);
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static struct proc_dir_entry *proc_dir_ilitek;
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| typedef struct {
 | |
| 	char *name;
 | |
| 	struct proc_dir_entry *node;
 | |
| 	struct proc_ops *fops;
 | |
| 	bool isCreated;
 | |
| } proc_node;
 | |
| #else
 | |
| typedef struct {
 | |
| 	char *name;
 | |
| 	struct proc_dir_entry *node;
 | |
| 	struct file_operations *fops;
 | |
| 	bool isCreated;
 | |
| } proc_node;
 | |
| #endif
 | |
| 
 | |
| #if GENERIC_KERNEL_IMAGE
 | |
| static int proc_show_mp_test_result_read(struct inode *inode, struct file *file)
 | |
| {
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	return single_open(file, ilitek_proc_mp_result_show, NULL);
 | |
| }
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_show_mp_test_result_fops = {
 | |
| 	.proc_open = proc_show_mp_test_result_read,
 | |
| 	.proc_read = seq_read,
 | |
| 	.proc_lseek = seq_lseek,
 | |
| 	.proc_release = single_release,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_show_mp_test_result_fops = {
 | |
| 	.open = proc_show_mp_test_result_read,
 | |
| 	.read = seq_read,
 | |
| 	.llseek = seq_lseek,
 | |
| 	.release = single_release,
 | |
| };
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_mp_lcm_on_test_fops = {
 | |
| 	.proc_read = ilitek_node_mp_lcm_on_test_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_mp_lcm_on_test_fops = {
 | |
| 	.read = ilitek_node_mp_lcm_on_test_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_mp_lcm_off_test_fops = {
 | |
| 	.proc_read = ilitek_node_mp_lcm_off_test_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_mp_lcm_off_test_fops = {
 | |
| 	.read = ilitek_node_mp_lcm_off_test_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_ver_info_fops = {
 | |
| 	.proc_read = ilitek_node_ver_info_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_ver_info_fops = {
 | |
| 	.read = ilitek_node_ver_info_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_change_list_fops = {
 | |
| 	.proc_read = ilitek_node_change_list_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_change_list_fops = {
 | |
| 	.read = ilitek_node_change_list_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if DMESG_SEQ_FILE
 | |
| static int ilitek_proc_seq_debug_message_read(struct inode *inode, struct file *file)
 | |
| {
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	return single_open(file, ilitek_proc_debug_message_show, NULL);
 | |
| }
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_debug_message_fops = {
 | |
| 	.proc_open = ilitek_proc_seq_debug_message_read,
 | |
| 	.proc_read = seq_read,
 | |
| 	.proc_lseek = seq_lseek,
 | |
| 	.proc_release = single_release,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_debug_message_fops = {
 | |
| 	.open = ilitek_proc_seq_debug_message_read,
 | |
| 	.read = seq_read,
 | |
| 	.llseek = seq_lseek,
 | |
| 	.release = single_release,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #else
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_debug_message_fops = {
 | |
| 	.proc_read = ilitek_proc_debug_message_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_debug_message_fops = {
 | |
| 	.read = ilitek_proc_debug_message_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| #endif
 | |
| 
 | |
| static int ilitek_proc_seq_debug_all_message_read(struct inode *inode, struct file *file)
 | |
| {
 | |
| 	if (atomic_read(&ilits->tp_reset) == START) {
 | |
| 		ILI_ERR("ignore request! tp reset atomic is START.\n");
 | |
| 		return -EINVAL;
 | |
| 	}
 | |
| 
 | |
| 	return single_open(file, ilitek_proc_debug_all_message_show, NULL);
 | |
| }
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_debug_all_message_fops = {
 | |
| 	.proc_open = ilitek_proc_seq_debug_all_message_read,
 | |
| 	.proc_read = seq_read,
 | |
| 	.proc_lseek = seq_lseek,
 | |
| 	.proc_release = single_release,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_debug_all_message_fops = {
 | |
| 	.open = ilitek_proc_seq_debug_all_message_read,
 | |
| 	.read = seq_read,
 | |
| 	.llseek = seq_lseek,
 | |
| 	.release = single_release,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_debug_all_message_switch_fops = {
 | |
| 	.proc_read = ilitek_proc_debug_all_switch_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_debug_all_message_switch_fops = {
 | |
| 	.read = ilitek_proc_debug_all_switch_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_debug_message_switch_fops = {
 | |
| 	.proc_read = ilitek_proc_debug_switch_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_debug_message_switch_fops = {
 | |
| 	.read = ilitek_proc_debug_switch_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_ioctl_fops = {
 | |
| 		.proc_ioctl = ilitek_node_ioctl,
 | |
| #ifdef CONFIG_COMPAT
 | |
| 		.proc_compat_ioctl = ilitek_node_compat_ioctl,
 | |
| #endif
 | |
| 		.proc_write = ilitek_node_ioctl_write,
 | |
| 		.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_ioctl_fops = {
 | |
| 	.unlocked_ioctl = ilitek_node_ioctl,
 | |
| #ifdef CONFIG_COMPAT
 | |
| 	.compat_ioctl = ilitek_node_compat_ioctl,
 | |
| #endif
 | |
| 	.write = ilitek_node_ioctl_write,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_fw_upgrade_fops = {
 | |
| 	.proc_read = ilitek_node_fw_upgrade_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_fw_upgrade_fops = {
 | |
| 	.read = ilitek_node_fw_upgrade_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_fw_process_fops = {
 | |
| 	.proc_read = ilitek_proc_fw_process_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_fw_process_fops = {
 | |
| 	.read = ilitek_proc_fw_process_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_get_delta_data_fops = {
 | |
| 	.proc_read = ilitek_proc_get_delta_data_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_get_delta_data_fops = {
 | |
| 	.read = ilitek_proc_get_delta_data_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_get_raw_data_fops = {
 | |
| 	.proc_read = ilitek_proc_fw_get_raw_data_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_get_raw_data_fops = {
 | |
| 	.read = ilitek_proc_fw_get_raw_data_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_rw_tp_reg_fops = {
 | |
| 	.proc_read = ilitek_proc_rw_tp_reg_read,
 | |
| 	.proc_write = ilitek_proc_rw_tp_reg_write,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_rw_tp_reg_fops = {
 | |
| 	.read = ilitek_proc_rw_tp_reg_read,
 | |
| 	.write = ilitek_proc_rw_tp_reg_write,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_fw_pc_counter_fops = {
 | |
| 	.proc_read = ilitek_proc_fw_pc_counter_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_fw_pc_counter_fops = {
 | |
| 	.read = ilitek_proc_fw_pc_counter_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_get_debug_mode_data_fops = {
 | |
| 	.proc_read = ilitek_proc_get_debug_mode_data_read,
 | |
| 	.proc_write = ilitek_proc_get_debug_mode_data_write,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_get_debug_mode_data_fops = {
 | |
| 	.read = ilitek_proc_get_debug_mode_data_read,
 | |
| 	.write = ilitek_proc_get_debug_mode_data_write,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_debug_level_fops = {
 | |
| 	.proc_read = ilitek_proc_debug_level_read,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_debug_level_fops = {
 | |
| 	.read = ilitek_proc_debug_level_read,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_sram_test_fops = {
 | |
| 	.proc_read = ilitek_proc_sram_test_info,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_sram_test_fops = {
 | |
| 	.read = ilitek_proc_sram_test_info,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| #if LINUX_VERSION_CODE > KERNEL_VERSION(5, 6, 0)
 | |
| static struct proc_ops proc_fw_cmd_fops = {
 | |
| 	.proc_read = ilitek_proc_fw_cmd_read,
 | |
| 	.proc_write = ilitek_proc_fw_cmd_write,
 | |
| 	.proc_lseek = default_llseek,
 | |
| };
 | |
| #else
 | |
| static struct file_operations proc_fw_cmd_fops = {
 | |
| 	.read = ilitek_proc_fw_cmd_read,
 | |
| 	.write = ilitek_proc_fw_cmd_write,
 | |
| 	.llseek = default_llseek,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| proc_node iliproc[] = {
 | |
| 	{"ioctl", NULL, &proc_ioctl_fops, false},
 | |
| 	{"fw_process", NULL, &proc_fw_process_fops, false},
 | |
| 	{"fw_upgrade", NULL, &proc_fw_upgrade_fops, false},
 | |
| 	{"debug_level", NULL, &proc_debug_level_fops, false},
 | |
| 	{"mp_lcm_on_test", NULL, &proc_mp_lcm_on_test_fops, false},
 | |
| 	{"mp_lcm_off_test", NULL, &proc_mp_lcm_off_test_fops, false},
 | |
| 	{"debug_message", NULL, &proc_debug_message_fops, false},
 | |
| 	{"debug_message_switch", NULL, &proc_debug_message_switch_fops, false},
 | |
| 	{"debug_all_message", NULL, &proc_debug_all_message_fops, false},
 | |
| 	{"debug_all_message_switch", NULL, &proc_debug_all_message_switch_fops, false},
 | |
| 	{"fw_pc_counter", NULL, &proc_fw_pc_counter_fops, false},
 | |
| 	{"show_delta_data", NULL, &proc_get_delta_data_fops, false},
 | |
| 	{"show_raw_data", NULL, &proc_get_raw_data_fops, false},
 | |
| 	{"get_debug_mode_data", NULL, &proc_get_debug_mode_data_fops, false},
 | |
| 	{"rw_tp_reg", NULL, &proc_rw_tp_reg_fops, false},
 | |
| 	{"ver_info", NULL, &proc_ver_info_fops, false},
 | |
| 	{"change_list", NULL, &proc_change_list_fops, false},
 | |
| 	{"sram_test", NULL, &proc_sram_test_fops, false},
 | |
| 	{"fw_cmd", NULL, &proc_fw_cmd_fops, false},
 | |
| #if GENERIC_KERNEL_IMAGE
 | |
| 	{"show_mp_test_result", NULL, &proc_show_mp_test_result_fops, false},
 | |
| #endif
 | |
| };
 | |
| 
 | |
| void ili_node_init(void)
 | |
| {
 | |
| 	int i = 0;
 | |
| 
 | |
| 	proc_dir_ilitek = proc_mkdir("ilitek", NULL);
 | |
| 
 | |
| 	for (; i < ARRAY_SIZE(iliproc); i++) {
 | |
| 		iliproc[i].node = proc_create(iliproc[i].name, 0644, proc_dir_ilitek, iliproc[i].fops);
 | |
| 
 | |
| 		if (iliproc[i].node == NULL) {
 | |
| 			iliproc[i].isCreated = false;
 | |
| 			ILI_ERR("Failed to create %s under /proc\n", iliproc[i].name);
 | |
| 		} else {
 | |
| 			iliproc[i].isCreated = true;
 | |
| 			ILI_INFO("Succeed to create %s under /proc\n", iliproc[i].name);
 | |
| 		}
 | |
| 	}
 | |
| }
 |