Skip to content

shashi918/ipio_touch_driver

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Introduce

Ipio touch driver is implemented by ILI Technology Corp, which is mainly used on its new generation touch ICs, TDDI.

Support ICs

The following lists which of TDDI IC types supported by the driver.

  • ILI9881F
  • ILI9881H

Support platform

  • Firefly-RK3288 (Rockchip)
  • Helio X20 (MT6797)
  • Qualcomm
  • SPRD

The default in this driver works on Qualcomm platform. If you'd like to port other platforms with this driver, please modify the number shown on below to fit it:

common.h

/* A platform currently supported by driver */
#define PT_QCOM	1
#define PT_MTK	2
#define PT_SPRD	3
#define TP_PLATFORM PT_QCOM

Interface

This driver supports SPI interface in the version of 1.0.3.0 above. If you'd like to change the interface between I2C and SPI:

/* A interface currently supported by driver */
#define I2C_INTERFACE 1
#define SPI_INTERFACE 2
#define INTERFACE SPI_INTERFACE

Note that SPI is only used on ILI9881H series.

Functions

Gesture

To enable the support of this feature, you can either open it by its node under /proc :

echo on > /proc/ilitek/gesture
echo off > /proc/ilitek/gesture

or change its variable from the file config.c :

core_config->isEnableGesture = false;

Check battery status

Some specific cases with power charge may affect on our TDDI IC so that we need to protect it if the event is occurring.

In order to enable this function, the first you need to do is to enable its macro at common.h

/* Check battery's status in order to avoid some effects from charge. */
#define BATTERY_CHECK

Once the function has been built in, you must have to on it by echoing:

echo on > /proc/ilitek/check_battery
echo off > /procilitek/check_battery

Or you can run it by default by setting its flag as true.

ipd->isEnablePollCheckPower = true;

DMA

If your platform needs to use DMA with I2C, you can open its macro from common.h :

#define ENABLE_DMA

Note, it is disabled as default.

I2C R/W Segment

Some of platforms with i2c bus may have no ability to R/W data with large length at once, so we provide th way of segmental operation.

Before enable its macro, you first need to know how much length your platform could accept. In core/i2c.c where you can find its variable:

core_i2c->seg_len = 256; // length of segment

You can change its value as long as you know the length that your platform can work on.

After that, as mentioned before, you need to enable its macro, which defines at common.h, to actually let driver run its function.

/* Split the length written to or read from IC via I2C. */
#define I2C_SEGMENT

FW upgrade at boot time

Apart from manual firmware upgrade, we also provide the way of upgrading firmware when system boots initially as long as the verions of firmware

in the IC is different the version that you're going to upgrade.

/* Be able to upgrade fw at boot stage */
#define BOOT_FW_UPGRADE

Glove/Proximity/Phone cover

These features need to be opened by the node only.

echo enaglove > /proc/ilitek/ioctl  --> enale glove
echo disglove > /proc/ilitek/ioctl  --> disable glove
echo enaprox > /proc/ilitek/ioctl   --> enable proximity
echo disprox > /proc/ilitek/ioctl   --> disable proximity
echo enapcc > /proc/ilitek/ioctl    --> enable phone cover
echo dispcc > /proc/ilitek/ioctl    --> disable phone cover

The metho of debug

To do so, you must firstlly ensure that the version of image is compiled for the debug instead of the user, otherwise it won't allow users to write commands through our device nodes.

Debug message

It is important to see more details with debug messages if an error happends somehow. To look up them, you can set up debug level via a node called debug_level under /proc.

At the beginning, you should read its node by cat to see what the levels you can choose for.

cat /proc/ilitek/debug_level

DEBUG_NONE = 0
DEBUG_IRQ = 1
DEBUG_FINGER_REPORT = 2
DEBUG_FIRMWARE = 4
DEBUG_CONFIG = 8
DEBUG_I2C = 16
DEBUG_BATTERY = 32
DEBUG_MP_TEST = 64
DEBUG_IOCTL = 128
DEBUG_NETLINK = 256
DEBUG_ALL = -1

The default level is zero once you get the driver at the first time. Let's say that we want to check out what is going on when the driver is upgrading firmware.

echo 4 > /proc/ilitek/debug_level

The result will only print the debug message with the process of firmware. Furthermore, you can also add two or three numbers to see multiple debug levels.

echo 7 > /proc/ilitek/debug_level

In this case the debusg message prints the status of IRQ, FINGER_REPORT and FIRMWARE. Finally, you can definitly see all of them without any thoughts.

echo -1 > /proc/ilitek/debug_level

I2C R/W

Sometime it is necessary to see IC's direct output by sending I2C commands in special cases.

We provide three functions to achieve it by echoing a specific device nodev which is created under /proc/ilitek/ioctl.

The command line defines as below :

# echo <function>,<length>,<data> > /proc/ilitek/ioctl

The comma must be added in each following command to let the driver recognize them.

In the function you can order specific actions to operate I2C such as Write (i2c_w), Read (i2c_r) and Write/Read (i2c_w_r). For instance, if you want to order write command, you can then type this as following:

# echo i2c_w,0x3,0x40,0x0,0x1

In this case the function is Write, the length is 3, and the i2c command is 0x40, 0x0 and 0x1. Note that it is important to add "0x" with every numbers that you want to cmmand except for the functions.

Additionly, we offer a useful feature to do Write/Read at once: Delay time. In this function it will do Write first and then delay a certain time before reading data through I2C. Note that the default of delay time is 1ms

# echo i2c_w_r, <length of write>, <length of read>, <delay time>, <data>

File structure

├── common.h
├── core
│   ├── config.c
│   ├── config.h
│   ├── finger_report.c
│   ├── finger_report.h
│   ├── firmware.c
│   ├── firmware.h
│   ├── flash.c
│   ├── flash.h
│   ├── gesture.c
│   ├── gesture.h
│   ├── i2c.c
│   ├── i2c.h
│   ├── Makefile
│   ├── mp_test.c
│   ├── mp_test.h
│   ├── parser.c
│   ├── parser.h
│   ├── protocol.c
│   ├── protocol.h
│   ├── spi.c
│   └── spi.h
├── Makefile
├── platform.c
├── platform.h
├── README.md
└── userspace.c

  • The concepts of this driver is suppose to hide details, and you should ignore the core functions and follow up the example code platform.c to write your own platform c file or just modify it.

  • If you want to create more nodes on the device driver for user space, just refer to userspace.c.

  • The directory Core includes our touch ic settings, functions and other features. If you'd like to write an application in user space, can just copy the directory to your workspace and call those functions by including header files.

Porting

Tell driver what IC types it should support to.

To void any undefined exeception, you should know what types of IC on the platform and what the current type of IC this driver supports for.

/* An Touch IC currently supported by driver */
#define CHIP_TYPE_ILI7807	0x7807
#define CHIP_TYPE_ILI9881	0x9881
#define TP_TOUCH_IC		CHIP_TYPE_ILI9881

In this case the driver now supports the type of ILI9881.

DTS example code

&i2c1 {
		ts@41 {
			status = "okay";
        	compatible = "tchip,ilitek";
      		reg = <0x41>;
         	touch,irq-gpio = <&gpio8 GPIO_A7 IRQ_TYPE_EDGE_RISING>;
         	touch,reset-gpio = <&gpio8 GPIO_A6 GPIO_ACTIVE_LOW>;
    	};

};

In this case the slave address is 0x41, and the name of table calls tchip,ilitek. touch,irq-gpio and touch,reset-gpio represent INT pin and RESET pin separately.

Release Note

  • V1.0.3.7

    • Usiing devm (resource-managed) to allocate memory for the core structures.
    • Patch open test.
    • Fixed FW mode switch to be more readable.
    • Rewrite HW CRC mechnaism.
    • Improved the mechnaism of check fw upgrade.
  • V1.0.3.6

    • Remove ILI7807(F & H) from support list.
    • Add ESD check
    • In boot upgrade, we compare HW and Hex CRC to see if need to do upgrade process rathan than just check firmware version.
    • Fixed MP short calculation.
    • Fixed wrong addrees while polling busy flag in fw upgrade.
    • Add MP retry mechanism, default is open and do three times.
    • Fixed some bugs.
  • V1.0.3.5

    • Fixed issue that coludn't read type option from INI file.
    • Delete redundant buffer memory allocated by kernel in MP.
    • No need to disable WDT when to exit ICE mode.
  • V1.0.3.4

    • Support MP CDC command under protocol 5.3.0.
    • Add a switch of watch dog.
    • Modified MP test item folloing with INI section.
  • V1.0.3.3

    • Fixed some bugs in loading gestue code.
    • Fixed the format of CSV output.
    • Added HW CRC read from DMA.
    • Added features to distinguish the golden in INI file.
    • Adjusted code style.
    • Added the node to test LCM ON/OFF (only for OPPO).
  • V1.0.3.2

    • Added gesture function in SPI.
    • Added loading code in gesture mode.
    • Fixed host download error when there is no hex to be read.
  • V1.0.3.1

    • Fixed wrong output in open test.
    • Fixed failure of LCM control.
    • Fixed the incorrect result of MP test after run.
    • Added two MP test items: Doze mode with LCM off.
    • Changed the sequence of MP test.
  • V1.0.3.0

    • Supports SPI interface
    • Remove the check of detection of chip id in init time.
    • Add new MP test & flow.
    • CDC commands read from INI file in protocol v5.4.0.
    • Recovery mechanism in SPI interface.
    • In MP test, ther are three ways to check busy when getting raw data: Polling, INT and mdelay.
  • V1.0.2.0

    • Fully support new IC type, ILI9881H.
    • Fixed the crash due to the free func while removing driver. (Module built)
    • Fixed the issue of timeout while switching mp mode.
    • Fixed the calculation of open cap test.
    • CSV can be overwriteen directly. (No necearry to delete it before test.)
    • MP Test only runs signle test time at once. If you'd like to run multiple tests, call more !
    • Fixed some bugs in mp test.
    • Rmove RK platform.
    • The setting of resolution gets from FW as default.
  • V1.0.1.3

    • Fixed many errors in mp test.
    • Adjusted code style as unix-like.
    • Support SPRD platform.
    • Won't set protect bit in flash register after firmware upgraded.
  • V1.0.1.2

    • Introduce Test Mode and MP Test function.
    • Add gesture code.
    • Add a debug node that can be run under user-built image.
    • Rewrote Function Control.
    • Fixed several bugs.
  • V1.0.1.1

    • Add i2c segmental read.
    • Redesign protocol structure. The protocol now became single moudle to have its own c file.
    • Define macros to enable some common functions.
    • Enable IRQ before handling the event triggered by fw.
    • Add block tag at boot upgrade and reserved block for customers.
    • Support new type of version of protocol (expend to 3 byte).
    • Able to print report data if image is built for user
  • V1.0.1.0 (Offical Release)

    • Fixed the size of CTPM_FW isn't subtracted by 32 before filling data into buffer.
    • FW upgrade at boot stage is disable as default.
  • V1.0.0.10

    • Fixed the issue of I2CUart when its length of next buffer is larger than previous one.
    • Add FW upgrade at boot stage. It will be actiaved when the version of FW that is going to upgrade is different the previous version, otherwise it will deny to upgrade.
  • V1.0.0.9

    • Add a new way to program firmware if the hex file includes block information.
    • Define the rule to show up detailed debug messages.
    • Add a node to enable the thread to check battery status.
    • Fix some bugs.
  • V1.0.0.8

    • Add support of MTK and DMA with I2C.
    • Add kthread to handle interrupt event.
    • Add support of gesture wake up in suspend/resume.
    • Remove power supply notifier at check battery status.
    • Add the functions such as glove, proximity and phone cover.
    • Support new calculation with i2cuart mode.
  • V1.0.0.7

    • Fixed issue of showing upgrade status while using APK
    • Added a flag to enable if resolution is set by default or fw
    • support the length of i2cuart and send to users with one package
    • i2c error is no long showing up if doing ic reset
    • Added a feature to check battery status
    • fixed the error while programming fw (garbage data left)
  • V1.0.0.6

    • Finger report won't send to user if checksum error occurs
    • Fixed the error sometimer work queue couldn't be executed while interrupting
  • V1.0.0.5

    • Fix the error of checksum with finger report
    • Add flash table in order to get flash information dynamatically.
    • fix the error crc to calculate length instead of address.
    • Optimise the calculation of fw upgrade
    • Remove ILI2121 from support list
    • Remove the old method of fw upgrade
    • Add the delay of 1ms after sending 0xF6 command
  • V1.0.0.4

    • Add 7807H in the support list
    • Support 7807 FW upgrade
    • Set 1920*1080 as fixed resolution
    • Add 0xF6 cmd for P5.0 befre reading data
    • Change Netlink's port from 31 to 21
    • Add Regulator power on
    • Add I2CUART mode
    • Add a new way to program flash
  • V1.0.0.3

    • Fixed the issue of create skb buff in netlink
    • Fixed the issue of doing bitwise with tp info got from ic
    • Improved the stability with IRAM upgrade.
    • Improved the stability while getting chip id, particularly 7807F.
    • Added Notifier FB as main suspend/resume function called.
    • Added MP Test in Test mode but 7807F not supported it yet.
    • Optimised code structure.
  • V1.0.0.2

    • Fixed the issue of no resposne while using A protocol.
    • Now the resolution of input device can correctly be set by TP info.
    • Added compiler flag -Wall
    • Added disable/enable irq while chiang firmware mode before and after.
    • Added dynamic debug outputs.
    • Added a feature that allows firmware upgrading into IRAM directly.
  • V1.0.0.1

    • Support firmware upgrade for 9881F
    • Improved the stability while upgrading firmware
    • Improved the stability while reading chid id from touch ic
    • Fixed some bugs
  • V1.0.0.0

    • Support ILI7807F, ILI9881F
    • Support protocol v5.0
    • Support upgrade firmware for 7807F (9881F not yet)
    • Support mode switch (demo/debug/test/i2cUart)
    • Support demo/debug mode with packet ID while reporting figner touch.
    • Support early suspend
    • Fixed some bugs

Releases

No releases published

Packages

No packages published

Languages

  • C 99.8%
  • Other 0.2%