Linux userspace driver to enable and disable the touchpads on TongFang/Uniwill laptops using a HID command.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Go to file
Werner Sembach 3f349b2c8c
Automatically set dependencies
4 years ago
res Add license text to all files and auto detect version from git tags 4 years ago
.gitignore Automatically set dependencies 4 years ago
CMakeLists.txt Automatically set dependencies 4 years ago
LICENSE.txt Cleanup 4 years ago
MunkeiVersionFromGit.cmake Add license text to all files and auto detect version from git tags 4 years ago
ReadMe.md Update ReadMe.md 4 years ago
setup-gnome.cpp Merge GNOME and KDE logic and decide in programm what to run 4 years ago
setup-gnome.h Merge GNOME and KDE logic and decide in programm what to run 4 years ago
setup-kde.cpp Add handler for KDE suspend/resume 4 years ago
setup-kde.h Merge GNOME and KDE logic and decide in programm what to run 4 years ago
touchpad-control.cpp Merge GNOME and KDE logic and decide in programm what to run 4 years ago
touchpad-control.h Merge GNOME and KDE logic and decide in programm what to run 4 years ago
tuxedo-touchpad-switch.cpp Merge GNOME and KDE logic and decide in programm what to run 4 years ago

ReadMe.md

This a proof-of-concept Linux userspace driver to hardware-enable/-disable the touchpads on TongFang/Uniwill laptops. This will also trigger the disabled-led, formerly unfunctional under linux.

It syncs up with the software toggle in the gnome settings deamon.

It comes with some known disfuctionalities:

  • only works on desktop evnironments using gsettings/gio
  • does not work on loginscreen(gdm)
  • needs to be started for every user seperatly
  • every user needs write access to the /dev/hidraw* device for the touchpad (udev *.rules included)
  • switching between 2 users is not detected (on next toggle the software and hardware disable will be in sync again however)

Author: Werner Sembach

Raw i2c communication with the touchpad for reference:

0x22 0x00 0x37 0x03 0x23 0x00 0x04 0x00 0x07 0x03
 [^^   ^^] (?max?) length of report? in little endian
            ^ 2 bits reserved + report type
             ^ report id (defined by touchpad controller?
                 ^ reserved
                  ^ opcode (0x2 = GET_REPORT, 0x3 = SET_REPORT)
                     [^^   ^^   ^^   ^^   ^^] ?i2c-hid stuff?
                                           ^ ?report id again?
                                               ^^ report/payload: defined by touchpad controller? 0x03 enabled (0x02 auch, keine ahnung was das unterste bit tut), 0x00 disabled