Ulf: Ritesh has collected logs showing that his Realtek RTS5129 USB card reader (drivers/mfd/rtsx_usb.c, drivers/mmc/host/rtsx_usb_sdmmc.c) goes into runtime autosuspend every 3 seconds and then immediately resumes. This sounds like something is failing to call pm_runtime_mark_last_busy(). He's using a 4.7 kernel. In addition, the device gets disconnected from the USB bus from time to time. This appears to be a completely separate issue. For now, I'd like to fix the runtime PM problem. But I don't know anything about the mmc core, so perhaps you can help. On Thu, 25 Aug 2016, Ritesh Raj Sarraf wrote: > > Do you happen to know which driver is being used: the memstick > > (rtsx_usb_ms) or mmc (rtsx_usb_sdmmc) driver? I suppose this may > > depend on what type of card you insert in the reader. > > > > > I think it is the rtsx_usb_sdmmc which is in use. I removed the rtsx_usb_ms > kernel module and still was able to access the sdcard. > > rrs@learner:~$ lsmod | grep usb_ms > 2016-08-25 / 18:45:52 ♒♒♒ ☹ => 1 > > rrs@learner:~$ lsmod | grep usb_sd > rtsx_usb_sdmmc 24576 0 > rtsx_usb 24576 1 rtsx_usb_sdmmc > mmc_core 135168 4 mmc_block,sdhci,sdhci_acpi,rtsx_usb_sdmmc > 2016-08-25 / 18:45:55 ♒♒♒ ☺ > > > The interesting bit is that when I enter the adapter into the reader, I get the > following error 5 times, and then it can access the card. > > [ 496.822613] mmc0: tuning execution failed: -22 > [ 496.822629] mmc0: error -22 whilst initialising SD card > [ 501.980908] mmc0: tuning execution failed: -22 > [ 501.980922] mmc0: error -22 whilst initialising SD card > [ 507.119953] mmc0: tuning execution failed: -22 > [ 507.119968] mmc0: error -22 whilst initialising SD card > [ 513.148143] mmc0: tuning execution failed: -22 > [ 513.148157] mmc0: error -22 whilst initialising SD card > [ 518.702215] mmc0: tuning execution failed: -22 > [ 518.702222] mmc0: error -22 whilst initialising SD card > [ 524.081122] mmc0: new ultra high speed SDR50 SDHC card at address 0002 > [ 524.082596] mmcblk0: mmc0:0002 NCard 14.9 GiB > [ 524.084240] mmcblk0: p1 > [ 524.306434] FAT-fs (mmcblk0p1): utf8 is not a recommended IO charset for FAT > filesystems, filesystem will be case sensitive! I can't tell why those errors occur. It would require more debugging. At least they don't seem to cause any serious problems. > With your patch applied, the initial errors messages (xhci_hcd 0000:00:14.0: dev > 4 ep1out scatterlist error -104/-110) are not seen so far. This is because those errors occur when the device goes into runtime autosuspend and the computer tries to communicate with it while it is suspended. Both things (the autosuspend and the communication attempt) are bugs in the drivers. > The device does reset (as you had mentioned), but it doesn't seem to have any > power drain related negative effects. > > > rrs@learner:~$ less /var/tmp/dmesg-post-patch.txt | tail -n 25 > [11922.283067] wlan0: RX AssocResp from 00:40:77:bb:55:12 (capab=0x411 status=0 > aid=1) > [11922.283743] wlan0: associated > [11922.283801] IPv6: ADDRCONF(NETDEV_CHANGE): wlan0: link becomes ready > [11922.883849] systemd[1]: apt-daily.timer: Adding 8h 36min 18.323966s random > time. > [11923.081426] systemd[1]: apt-daily.timer: Adding 2h 23min 22.221062s random > time. > [13799.616838] atkbd serio0: Unknown key pressed (translated set 2, code 0xbe on > isa0060/serio0). > [13799.616843] atkbd serio0: Use 'setkeycodes e03e <keycode>' to make it known. > [13799.625901] atkbd serio0: Unknown key released (translated set 2, code 0xbe > on isa0060/serio0). > [13799.625905] atkbd serio0: Use 'setkeycodes e03e <keycode>' to make it known. > [13800.547966] usb 1-4: USB disconnect, device number 15 Spontaneous disconnect followed by reconnect a little later... > [13801.707137] usb 1-4: new high-speed USB device number 16 using xhci_hcd > [13801.880788] usb 1-4: New USB device found, idVendor=0bda, idProduct=0129 > [13801.880791] usb 1-4: New USB device strings: Mfr=1, Product=2, SerialNumber=3 > [13801.880792] usb 1-4: Product: USB2.0-CRW > [13801.880793] usb 1-4: Manufacturer: Generic > [13801.880794] usb 1-4: SerialNumber: 20100201396000000 > [13802.809031] usb 1-4: USB disconnect, device number 16 > [13803.390459] usb 1-4: new high-speed USB device number 18 using xhci_hcd > [13808.807084] usb 1-4: new high-speed USB device number 19 using xhci_hcd > [13808.980827] usb 1-4: New USB device found, idVendor=0bda, idProduct=0129 > [13808.980831] usb 1-4: New USB device strings: Mfr=1, Product=2, SerialNumber=3 > [13808.980833] usb 1-4: Product: USB2.0-CRW > [13808.980834] usb 1-4: Manufacturer: Generic > [13808.980835] usb 1-4: SerialNumber: 20100201396000000 > [14367.255033] usb 1-7: reset full-speed USB device number 5 using xhci_hcd > 2016-08-25 / 18:53:16 ♒♒♒ ☺ > > Note: These resets are seen without any card/adapter in the reader. The computer probably still wants to communicate with the reader, in order to check whether a card has been inserted. In theory this shouldn't be necessary, because the card reader should perform a remote wakeup when a card is inserted or removed. It might not support this feature, however -- although your "lsusb -v" output shows that it does support remote wakeup. > > As you mentioned above, there's another aspect to power management > > besides runtime PM, namely Link Power Management. Perhaps the device > > can't handle LPM. > > > > You can test this by editing the usb_device_supports_lpm() routine in > > drivers/usb/core/hub.c. If you make it always return 0 immediately, > > that will disable LPM for all USB devices. If the spontaneous > > disconnects don't reappear, we'll have the answer. > > > > Alan Stern > > > > > I'll try this out on a new build and share my results again on this thread. > > As for the patch, will it qualify for inclusion into the mainline kernel ? You mean the patch that disables autosuspend in the rtsx_usb driver? No, it's not a real solution. We need to figure out why the device gets autosuspended every 3 seconds and fix that bug, not just eliminate all support for runtime PM. Alan Stern -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html