tests: Test suspend/resume and sysfs attributes in synaptics

This commit is contained in:
Benjamin Berg
2022-03-14 20:18:17 +01:00
parent 7b0093b4c6
commit 1f925fef7c
3 changed files with 186 additions and 149 deletions

Binary file not shown.

View File

@@ -1,10 +1,14 @@
#!/usr/bin/python3 #!/usr/bin/python3
import os
import gi import gi
gi.require_version('FPrint', '2.0') gi.require_version('FPrint', '2.0')
from gi.repository import FPrint, GLib from gi.repository import FPrint, GLib
ctx = GLib.main_context_default() import sys
import traceback
sys.excepthook = lambda *args : (traceback.print_exception(*args), sys.exit(1))
c = FPrint.Context() c = FPrint.Context()
c.enumerate() c.enumerate()
@@ -13,6 +17,24 @@ devices = c.get_devices()
d = devices[0] d = devices[0]
del devices del devices
usb_device = d.get_property('fpi-usb-device')
bus_num = usb_device.get_bus()
port = []
while True:
parent = usb_device.get_parent()
if parent is None:
break
port.append(str(usb_device.get_port_number()))
usb_device = parent
port = '.'.join(port)
persist = f'/sys/bus/usb/devices/{bus_num}-{port}/power/persist'
wakeup = f'/sys/bus/usb/devices/{bus_num}-{port}/power/wakeup'
# may not have written anything
assert open(persist).read().strip() == "0"
assert open(wakeup).read().strip() == "disabled"
assert d.get_driver() == "synaptics" assert d.get_driver() == "synaptics"
assert not d.has_feature(FPrint.DeviceFeature.CAPTURE) assert not d.has_feature(FPrint.DeviceFeature.CAPTURE)
assert d.has_feature(FPrint.DeviceFeature.IDENTIFY) assert d.has_feature(FPrint.DeviceFeature.IDENTIFY)
@@ -29,7 +51,7 @@ d.clear_storage_sync()
template = FPrint.Print.new(d) template = FPrint.Print.new(d)
def enroll_progress(*args): def enroll_progress(*args):
assert d.get_finger_status() == FPrint.FingerStatusFlags.NEEDED #assert d.get_finger_status() == FPrint.FingerStatusFlags.NEEDED
print('enroll progress: ' + str(args)) print('enroll progress: ' + str(args))
# List, enroll, list, verify, delete, list # List, enroll, list, verify, delete, list
@@ -41,6 +63,21 @@ print("enroll done")
print("verifying") print("verifying")
assert d.get_finger_status() == FPrint.FingerStatusFlags.NONE assert d.get_finger_status() == FPrint.FingerStatusFlags.NONE
# Inject a suspend/resume cycle into the verify
def suspend_resume():
d.suspend_sync()
assert open(persist).read().strip() == "0"
assert open(wakeup).read().strip() == "enabled"
assert open(persist, 'w').write('0\n')
d.resume_sync()
# This tests that libfprint doesn't write if the value is correct
# (i.e. the trailing \ would be lost inside umockdev if written)
assert open(persist).read() == "0\n"
assert open(wakeup).read().strip() == "disabled"
GLib.idle_add(suspend_resume, priority=GLib.PRIORITY_HIGH)
verify_res, verify_print = d.verify_sync(p) verify_res, verify_print = d.verify_sync(p)
assert d.get_finger_status() == FPrint.FingerStatusFlags.NONE assert d.get_finger_status() == FPrint.FingerStatusFlags.NONE
print("verify done") print("verify done")

View File

@@ -1,14 +1,14 @@
P: /devices/pci0000:00/0000:00:14.0/usb1/1-9 P: /devices/pci0000:00/0000:00:14.0/usb1/1-9
N: bus/usb/001/005 N: bus/usb/001/004=12010002FF10FF08CB06BD0000000000010109022700010100A0320904000003FF000000070501024000000705810240000007058303080004
E: DEVNAME=/dev/bus/usb/001/005 E: DEVNAME=/dev/bus/usb/001/004
E: DEVTYPE=usb_device E: DEVTYPE=usb_device
E: DRIVER=usb E: DRIVER=usb
E: PRODUCT=6cb/bd/0 E: PRODUCT=6cb/bd/0
E: TYPE=255/16/255 E: TYPE=255/16/255
E: BUSNUM=001 E: BUSNUM=001
E: DEVNUM=005 E: DEVNUM=004
E: MAJOR=189 E: MAJOR=189
E: MINOR=4 E: MINOR=3
E: SUBSYSTEM=usb E: SUBSYSTEM=usb
E: ID_VENDOR=06cb E: ID_VENDOR=06cb
E: ID_VENDOR_ENC=06cb E: ID_VENDOR_ENC=06cb
@@ -24,82 +24,82 @@ E: ID_USB_INTERFACES=:ff0000:
E: ID_VENDOR_FROM_DATABASE=Synaptics, Inc. E: ID_VENDOR_FROM_DATABASE=Synaptics, Inc.
E: ID_AUTOSUSPEND=1 E: ID_AUTOSUSPEND=1
E: ID_MODEL_FROM_DATABASE=Prometheus MIS Touch Fingerprint Reader E: ID_MODEL_FROM_DATABASE=Prometheus MIS Touch Fingerprint Reader
E: ID_PERSIST=0
E: ID_PATH=pci-0000:00:14.0-usb-0:9 E: ID_PATH=pci-0000:00:14.0-usb-0:9
E: ID_PATH_TAG=pci-0000_00_14_0-usb-0_9 E: ID_PATH_TAG=pci-0000_00_14_0-usb-0_9
E: LIBFPRINT_DRIVER=Synaptics Sensors A: authorized=1
A: authorized=1\n A: avoid_reset_quirk=0
A: avoid_reset_quirk=0\n A: bConfigurationValue=1
A: bConfigurationValue=1\n A: bDeviceClass=ff
A: bDeviceClass=ff\n A: bDeviceProtocol=ff
A: bDeviceProtocol=ff\n A: bDeviceSubClass=10
A: bDeviceSubClass=10\n A: bMaxPacketSize0=8
A: bMaxPacketSize0=8\n A: bMaxPower=100mA
A: bMaxPower=100mA\n A: bNumConfigurations=1
A: bNumConfigurations=1\n A: bNumInterfaces= 1
A: bNumInterfaces= 1\n A: bcdDevice=0000
A: bcdDevice=0000\n A: bmAttributes=a0
A: bmAttributes=a0\n A: busnum=1
A: busnum=1\n
A: configuration= A: configuration=
H: descriptors=12010002FF10FF08CB06BD0000000000010109022700010100A0320904000003FF000000070501024000000705810240000007058303080004 H: descriptors=12010002FF10FF08CB06BD0000000000010109022700010100A0320904000003FF000000070501024000000705810240000007058303080004
A: dev=189:4\n A: dev=189:3
A: devnum=5\n A: devnum=4
A: devpath=9\n A: devpath=9
L: driver=../../../../../bus/usb/drivers/usb L: driver=../../../../../bus/usb/drivers/usb
L: firmware_node=../../../../LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:1c/device:1d/device:28 L: firmware_node=../../../../LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:1c/device:1d/device:28
A: idProduct=00bd\n A: idProduct=00bd
A: idVendor=06cb\n A: idVendor=06cb
A: ltm_capable=no\n A: ltm_capable=no
A: maxchild=0\n A: maxchild=0
L: port=../1-0:1.0/usb1-port9 L: port=../1-0:1.0/usb1-port9
A: power/active_duration=82065\n A: power/active_duration=9424964
A: power/autosuspend=2\n A: power/autosuspend=2
A: power/autosuspend_delay_ms=2000\n A: power/autosuspend_delay_ms=2000
A: power/connected_duration=4271349\n A: power/connected_duration=866169213
A: power/control=auto\n A: power/control=auto
A: power/level=auto\n A: power/level=auto
A: power/persist=1\n A: power/persist=0
A: power/runtime_active_time=82975\n A: power/runtime_active_time=9431408
A: power/runtime_status=suspended\n A: power/runtime_status=active
A: power/runtime_suspended_time=4186597\n A: power/runtime_suspended_time=856661633
A: power/wakeup=disabled\n A: power/wakeup=disabled
A: power/wakeup_abort_count=\n A: power/wakeup_abort_count=
A: power/wakeup_active=\n A: power/wakeup_active=
A: power/wakeup_active_count=\n A: power/wakeup_active_count=
A: power/wakeup_count=\n A: power/wakeup_count=
A: power/wakeup_expire_count=\n A: power/wakeup_expire_count=
A: power/wakeup_last_time_ms=\n A: power/wakeup_last_time_ms=
A: power/wakeup_max_time_ms=\n A: power/wakeup_max_time_ms=
A: power/wakeup_total_time_ms=\n A: power/wakeup_total_time_ms=
A: quirks=0x0\n A: quirks=0x0
A: removable=fixed\n A: removable=fixed
A: rx_lanes=1\n A: rx_lanes=1
A: serial=c087f7d72126\n A: serial=c087f7d72126
A: speed=12\n A: speed=12
A: tx_lanes=1\n A: tx_lanes=1
A: urbnum=618\n A: urbnum=8945
A: version= 2.00\n A: version= 2.00
P: /devices/pci0000:00/0000:00:14.0/usb1 P: /devices/pci0000:00/0000:00:14.0/usb1
N: bus/usb/001/001=12010002090001406B1D020012050302010109021900010100E0000904000001090000000705810304000C N: bus/usb/001/001=12010002090001406B1D020016050302010109021900010100E0000904000001090000000705810304000C
E: DEVNAME=/dev/bus/usb/001/001 E: DEVNAME=/dev/bus/usb/001/001
E: DEVTYPE=usb_device E: DEVTYPE=usb_device
E: DRIVER=usb E: DRIVER=usb
E: PRODUCT=1d6b/2/512 E: PRODUCT=1d6b/2/516
E: TYPE=9/0/1 E: TYPE=9/0/1
E: BUSNUM=001 E: BUSNUM=001
E: DEVNUM=001 E: DEVNUM=001
E: MAJOR=189 E: MAJOR=189
E: MINOR=0 E: MINOR=0
E: SUBSYSTEM=usb E: SUBSYSTEM=usb
E: ID_VENDOR=Linux_5.12.9-300.fc34.x86_64_xhci-hcd E: ID_VENDOR=Linux_5.16.8-200.fc35.x86_64_xhci-hcd
E: ID_VENDOR_ENC=Linux\x205.12.9-300.fc34.x86_64\x20xhci-hcd E: ID_VENDOR_ENC=Linux\x205.16.8-200.fc35.x86_64\x20xhci-hcd
E: ID_VENDOR_ID=1d6b E: ID_VENDOR_ID=1d6b
E: ID_MODEL=xHCI_Host_Controller E: ID_MODEL=xHCI_Host_Controller
E: ID_MODEL_ENC=xHCI\x20Host\x20Controller E: ID_MODEL_ENC=xHCI\x20Host\x20Controller
E: ID_MODEL_ID=0002 E: ID_MODEL_ID=0002
E: ID_REVISION=0512 E: ID_REVISION=0516
E: ID_SERIAL=Linux_5.12.9-300.fc34.x86_64_xhci-hcd_xHCI_Host_Controller_0000:00:14.0 E: ID_SERIAL=Linux_5.16.8-200.fc35.x86_64_xhci-hcd_xHCI_Host_Controller_0000:00:14.0
E: ID_SERIAL_SHORT=0000:00:14.0 E: ID_SERIAL_SHORT=0000:00:14.0
E: ID_BUS=usb E: ID_BUS=usb
E: ID_USB_INTERFACES=:090000: E: ID_USB_INTERFACES=:090000:
@@ -111,60 +111,60 @@ E: ID_PATH_TAG=pci-0000_00_14_0
E: ID_FOR_SEAT=usb-pci-0000_00_14_0 E: ID_FOR_SEAT=usb-pci-0000_00_14_0
E: TAGS=:seat: E: TAGS=:seat:
E: CURRENT_TAGS=:seat: E: CURRENT_TAGS=:seat:
A: authorized=1\n A: authorized=1
A: authorized_default=1\n A: authorized_default=1
A: avoid_reset_quirk=0\n A: avoid_reset_quirk=0
A: bConfigurationValue=1\n A: bConfigurationValue=1
A: bDeviceClass=09\n A: bDeviceClass=09
A: bDeviceProtocol=01\n A: bDeviceProtocol=01
A: bDeviceSubClass=00\n A: bDeviceSubClass=00
A: bMaxPacketSize0=64\n A: bMaxPacketSize0=64
A: bMaxPower=0mA\n A: bMaxPower=0mA
A: bNumConfigurations=1\n A: bNumConfigurations=1
A: bNumInterfaces= 1\n A: bNumInterfaces= 1
A: bcdDevice=0512\n A: bcdDevice=0516
A: bmAttributes=e0\n A: bmAttributes=e0
A: busnum=1\n A: busnum=1
A: configuration= A: configuration=
H: descriptors=12010002090001406B1D020012050302010109021900010100E0000904000001090000000705810304000C H: descriptors=12010002090001406B1D020016050302010109021900010100E0000904000001090000000705810304000C
A: dev=189:0\n A: dev=189:0
A: devnum=1\n A: devnum=1
A: devpath=0\n A: devpath=0
L: driver=../../../../bus/usb/drivers/usb L: driver=../../../../bus/usb/drivers/usb
L: firmware_node=../../../LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:1c/device:1d L: firmware_node=../../../LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:1c/device:1d
A: idProduct=0002\n A: idProduct=0002
A: idVendor=1d6b\n A: idVendor=1d6b
A: interface_authorized_default=1\n A: interface_authorized_default=1
A: ltm_capable=no\n A: ltm_capable=no
A: manufacturer=Linux 5.12.9-300.fc34.x86_64 xhci-hcd\n A: manufacturer=Linux 5.16.8-200.fc35.x86_64 xhci-hcd
A: maxchild=12\n A: maxchild=12
A: power/active_duration=4270585\n A: power/active_duration=865968060
A: power/autosuspend=0\n A: power/autosuspend=0
A: power/autosuspend_delay_ms=0\n A: power/autosuspend_delay_ms=0
A: power/connected_duration=4272308\n A: power/connected_duration=866169920
A: power/control=auto\n A: power/control=auto
A: power/level=auto\n A: power/level=auto
A: power/runtime_active_time=4270770\n A: power/runtime_active_time=866093998
A: power/runtime_status=active\n A: power/runtime_status=active
A: power/runtime_suspended_time=0\n A: power/runtime_suspended_time=0
A: power/wakeup=disabled\n A: power/wakeup=disabled
A: power/wakeup_abort_count=\n A: power/wakeup_abort_count=
A: power/wakeup_active=\n A: power/wakeup_active=
A: power/wakeup_active_count=\n A: power/wakeup_active_count=
A: power/wakeup_count=\n A: power/wakeup_count=
A: power/wakeup_expire_count=\n A: power/wakeup_expire_count=
A: power/wakeup_last_time_ms=\n A: power/wakeup_last_time_ms=
A: power/wakeup_max_time_ms=\n A: power/wakeup_max_time_ms=
A: power/wakeup_total_time_ms=\n A: power/wakeup_total_time_ms=
A: product=xHCI Host Controller\n A: product=xHCI Host Controller
A: quirks=0x0\n A: quirks=0x0
A: removable=unknown\n A: removable=unknown
A: rx_lanes=1\n A: rx_lanes=1
A: serial=0000:00:14.0\n A: serial=0000:00:14.0
A: speed=480\n A: speed=480
A: tx_lanes=1\n A: tx_lanes=1
A: urbnum=463\n A: urbnum=9372
A: version= 2.00\n A: version= 2.00
P: /devices/pci0000:00/0000:00:14.0 P: /devices/pci0000:00/0000:00:14.0
E: DRIVER=xhci_hcd E: DRIVER=xhci_hcd
@@ -180,44 +180,44 @@ E: ID_PCI_INTERFACE_FROM_DATABASE=XHCI
E: ID_VENDOR_FROM_DATABASE=Intel Corporation E: ID_VENDOR_FROM_DATABASE=Intel Corporation
E: ID_AUTOSUSPEND=1 E: ID_AUTOSUSPEND=1
E: ID_MODEL_FROM_DATABASE=Cannon Point-LP USB 3.1 xHCI Controller E: ID_MODEL_FROM_DATABASE=Cannon Point-LP USB 3.1 xHCI Controller
A: ari_enabled=0\n A: ari_enabled=0
A: broken_parity_status=0\n A: broken_parity_status=0
A: class=0x0c0330\n A: class=0x0c0330
H: config=8680ED9D060490021130030C00008000040022EA000000000000000000000000000000000000000000000000AA179222000000007000000000000000FF010000 H: config=8680ED9D060490021130030C00008000040022EA000000000000000000000000000000000000000000000000AA179222000000007000000000000000FF010000FD0134808FC6FF8300000000000000007F6DDC0F0000000060069A2400000000316000000000000000000000000000000180C2C108000000000000000000000005908700D802E0FE0000000000000000090014F01000400100000000C10A080000080E00001800008F40020000010000000000000000000008000000040000000000000000000000000000000000000000000000000000000800000004000000000000000000000000000000000000000000000000000000B50F320112000000
A: consistent_dma_mask_bits=64\n A: consistent_dma_mask_bits=64
A: d3cold_allowed=1\n A: d3cold_allowed=1
A: dbc=disabled\n A: dbc=disabled
A: device=0x9ded\n A: device=0x9ded
A: dma_mask_bits=64\n A: dma_mask_bits=64
L: driver=../../../bus/pci/drivers/xhci_hcd L: driver=../../../bus/pci/drivers/xhci_hcd
A: driver_override=(null)\n A: driver_override=(null)
A: enable=1\n A: enable=1
L: firmware_node=../../LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:1c L: firmware_node=../../LNXSYSTM:00/LNXSYBUS:00/PNP0A08:00/device:1c
A: irq=128\n A: irq=126
A: local_cpulist=0-7\n A: local_cpulist=0-7
A: local_cpus=ff\n A: local_cpus=ff
A: modalias=pci:v00008086d00009DEDsv000017AAsd00002292bc0Csc03i30\n A: modalias=pci:v00008086d00009DEDsv000017AAsd00002292bc0Csc03i30
A: msi_bus=1\n A: msi_bus=1
A: msi_irqs/128=msi\n A: msi_irqs/126=msi
A: numa_node=-1\n A: numa_node=-1
A: pools=poolinfo - 0.1\nbuffer-2048 0 0 2048 0\nbuffer-512 0 0 512 0\nbuffer-128 0 0 128 0\nbuffer-32 0 0 32 0\nxHCI 1KB stream ctx arrays 0 0 1024 0\nxHCI 256 byte stream ctx arrays 0 0 256 0\nxHCI input/output contexts 9 12 2112 12\nxHCI ring segments 40 50 4096 50\nbuffer-2048 0 0 2048 0\nbuffer-512 0 0 512 0\nbuffer-128 6 32 128 1\nbuffer-32 0 0 32 0\n A: pools=poolinfo - 0.1\nbuffer-2048 0 0 2048 0\nbuffer-512 0 0 512 0\nbuffer-128 0 0 128 0\nbuffer-32 0 0 32 0\nxHCI 1KB stream ctx arrays 0 0 1024 0\nxHCI 256 byte stream ctx arrays 0 0 256 0\nxHCI input/output contexts 21 24 2112 24\nxHCI ring segments 68 80 4096 80\nbuffer-2048 0 38 2048 19\nbuffer-512 0 0 512 0\nbuffer-128 18 32 128 1\nbuffer-32 0 128 32 1
A: power/control=auto\n A: power/control=auto
A: power/runtime_active_time=4271635\n A: power/runtime_active_time=866094158
A: power/runtime_status=active\n A: power/runtime_status=active
A: power/runtime_suspended_time=0\n A: power/runtime_suspended_time=0
A: power/wakeup=enabled\n A: power/wakeup=enabled
A: power/wakeup_abort_count=0\n A: power/wakeup_abort_count=0
A: power/wakeup_active=0\n A: power/wakeup_active=0
A: power/wakeup_active_count=0\n A: power/wakeup_active_count=2
A: power/wakeup_count=0\n A: power/wakeup_count=0
A: power/wakeup_expire_count=0\n A: power/wakeup_expire_count=2
A: power/wakeup_last_time_ms=0\n A: power/wakeup_last_time_ms=476219021
A: power/wakeup_max_time_ms=0\n A: power/wakeup_max_time_ms=103
A: power/wakeup_total_time_ms=0\n A: power/wakeup_total_time_ms=207
A: power_state=D0\n A: power_state=D0
A: resource=0x00000000ea220000 0x00000000ea22ffff 0x0000000000140204\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n A: resource=0x00000000ea220000 0x00000000ea22ffff 0x0000000000140204\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000\n0x0000000000000000 0x0000000000000000 0x0000000000000000
A: revision=0x11\n A: revision=0x11
A: subsystem_device=0x2292\n A: subsystem_device=0x2292
A: subsystem_vendor=0x17aa\n A: subsystem_vendor=0x17aa
A: vendor=0x8086\n A: vendor=0x8086