login
Login
/
Register
Search
Search this site:
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2010
»
May
»
5
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
view
thread
Previous message: [
thread
] [
date
] [
author
]
Next message: [thread] [
date
] [
author
]
[view in full thread]
From: Jiri Kosina
Subject:
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
Date: Wednesday, May 5, 2010 - 1:55 pm
[ Jiri Slaby added to CC ] On Wed, 5 May 2010, Bruno Prémont wrote:
quoted text
> On Wed, 05 May 2010 Bruno Prémont <bonbons@linux-vserver.org> wrote: > > > On Tue, 04 May 2010 Jiri Kosina <jkosina@suse.cz> wrote: > > > > > On Tue, 4 May 2010, Oliver Neukum wrote: > > > > > > > > [ 477.543304] usb 1-2.1: usb_autosuspend_device: cnt 1 -> 0 > > > > > [ 477.543316] usbhid 1-2.1:1.1: __pm_runtime_suspend()! > > > > > [ 477.543326] usbhid 1-2.1:1.1: __pm_runtime_suspend() returns 0! > > > > > [ 477.543380] usbcore: registered new interface driver usbhid > > > > > [ 477.549457] usbhid: USB HID core driver > > > > > > > > > > And suspend is freezing inside of hid_cancel_delayed_stuff(usbhid) call > > > > > from hid_suspend() in drivers/hid/usbhid/hid-core.c ... > > > > > > > > > > Is it worth continuing iteration and adding further printk's down there? > > > > > Jiri, what's your opinion on this? > > > > > > > > Ugh. That looks like a bug in usbhid that I introduced. A fix is not trivial. > > > > In short, I did not think the device could be undergoing a queued resumption > > > > while suspend() is being called. I wonder why this is happening. > > > > > > Hmmm ... seems to me that in this case, the problem might be that there is > > > a device hanging in the air, for which the parsing of report descriptor > > > failed (interface .0002), but it's still somehow there on the bus. > > > > > > It's a bit strange that we are not seeing > > > > > > dev_err(&intf->dev, "can't add hid device: %d\n", ret); > > > > > > message from usbhid_probe(), are we? That would mean, that we are > > > returning ENODEV from the usb_driver->probe routine properly. > > > > > > Bruno, could you, for testing purposes, check, whether the patch below > > > changes the behavior you are seeing (and also check what the actual return > > > value from device_add() was, see the added printk()). > > > Thanks. > > > > > > > > > > > > drivers/hid/hid-core.c | 5 +++-- > > > drivers/hid/usbhid/hid-core.c | 4 ++-- > > > 2 files changed, 5 insertions(+), 4 deletions(-) > > > > > > diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c > > > index 2e2aa75..7186f9f 100644 > > > --- a/drivers/hid/hid-core.c > > > +++ b/drivers/hid/hid-core.c > > > @@ -1770,10 +1770,11 @@ int hid_add_device(struct hid_device *hdev) > > > hdev->vendor, hdev->product, atomic_inc_return(&id)); > > > > > > ret = device_add(&hdev->dev); > > > + printk(KERN_DEBUG "HID: device_add() returned %d\n", ret); > > > if (!ret) > > > hdev->status |= HID_STAT_ADDED; > > > - > > > - hid_debug_register(hdev, dev_name(&hdev->dev)); > > > + else > > > + hid_debug_register(hdev, dev_name(&hdev->dev)); > > > > > > return ret; > > > } > > > > Ok, I've been digging some further... > > > > The hid_device_probe properly returns -ENODEV, but: > > > > Call trace: > > [ 3228.866146] [<ffffffffa01a00e6>] hid_device_probe+0xd6/0x1f0 [hid] > > return -ENODEV > > [ 3228.874594] [<ffffffff8130995a>] driver_probe_device+0xaa/0x1d0 > > calls inlined really_probe from drivers/base/dd.c > > which ALLWAYS returns 0: > > dd.c:147 /* > > 148 * Ignore errors returned by ->probe so that the next driver can try > > 149 * its luck. > > 150 */ > > 151 ret = 0; > > and has on line 139 (under same failure label): > > dev->driver = NULL; > > [ 3228.882758] [<ffffffff81309b20>] ? __device_attach+0x0/0x50 > > [ 3228.890555] [<ffffffff81309b6b>] __device_attach+0x4b/0x50 > > lets 0 bubble up > > [ 3228.898272] [<ffffffff81308d28>] bus_for_each_drv+0x68/0x90 > > lets 0 bubble up > > [ 3228.906080] [<ffffffff81309c3b>] device_attach+0x8b/0xa0 > > lets 0 bubble up > > [ 3228.913603] [<ffffffff81308b15>] bus_probe_device+0x25/0x40 > > returns void and does WARN_ON(device_attach() < 0) > > [ 3228.921356] [<ffffffff81307166>] device_add+0x3d6/0x610 > > returns 0 here as there was no local error > > [ 3228.928772] [<ffffffffa019fc53>] hid_add_device+0x183/0x1e0 [hid] > > [ 3228.937098] [<ffffffffa01b4a77>] usbhid_probe+0x287/0x420 [usbhid] > > [ 3228.945535] [<ffffffffa005006d>] usb_probe_interface+0x14d/0x230 [usbcore] > > ... > > > > So IMHO in hid_add_device() we should also check for hdev->dev.driver > > when device_add() returns 0 and consider that one being NULL as a > > (possible) error. > > Something like the delow diff causes the HID registration to fail > gracefully and `echo devices > pm_test` suspend attempt to pass. > > (note, to be manually applied, is edited copy from console, so does > not preserve tabs and line numbers may not match due to debug printks > added all over the place) > > > I don't know what impact it could have on auto-probing of device > if a specialized HID driver that would fix reports or whatever was > loaded later on when device is already plugged into USB. > > Thanks, > Bruno > > > @@ -1770,11 +1779,13 @@ int hid_add_device(struct hid_device *hdev) > hdev->vendor, hdev->product, atomic_inc_return(&id)); > > ret = device_add(&hdev->dev); > - if (!ret) > + if (ret == 0 && !hdev->dev.driver) { > + device_del(&hdev->dev); > + ret = -ENODEV; > + } else { > hdev->status |= HID_STAT_ADDED; > - > - hid_debug_register(hdev, dev_name(&hdev->dev)); > - > + hid_debug_register(hdev, dev_name(&hdev->dev)); > + } > return ret; > } > EXPORT_SYMBOL_GPL(hid_add_device); >
-- Jiri Kosina SUSE Labs, Novell Inc. --
unsubscribe notice
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html
Please read the FAQ at
http://www.tux.org/lkml/
Previous message: [
thread
] [
date
] [
author
]
Next message: [thread] [
date
] [
author
]
Messages in current thread:
Re: s2ram slow (radeon) / failing (usb)
, Alan Stern
, (Mon May 3, 1:11 pm)
Re: s2ram slow (radeon) / failing (usb)
, Bruno Prémont
, (Mon May 3, 2:11 pm)
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
, Oliver Neukum
, (Mon May 3, 11:42 pm)
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
, Jiri Kosina
, (Tue May 4, 1:37 am)
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
, Bruno Prémont
, (Tue May 4, 2:04 pm)
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
, Jiri Kosina
, (Wed May 5, 5:58 am)
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
, Bruno Prémont
, (Wed May 5, 12:17 pm)
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
, Bruno Prémont
, (Wed May 5, 1:30 pm)
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
, Bruno Prémont
, (Wed May 5, 1:53 pm)
Re: [linux-pm] s2ram slow (radeon) / failing (usb)
, Jiri Kosina
, (Wed May 5, 1:55 pm)
Navigation
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Michael Trimarchi
Re: [PATCH] VFS: make file->f_pos access atomic on 32bit arch
Miklos Szeredi
[patch 14/15] vfs: more path_permission() conversions
Serge E. Hallyn
Re: [RFC v5][PATCH 7/8] Infrastructure for shared objects
Bernd Schmidt
Re: Dual-Licensing Linux Kernel with GPL V2 and GPL V3
Takashi Iwai
[PATCH 2/2] input: Add LED support to Synaptics device
git
:
Junio C Hamano
Re: mingw, windows, crlf/lf, and git
Eyvind Bernhardsen
Re: Where has "git ls-remote" reference pattern matching gone?
Shawn O. Pearce
Re: Switching from CVS to GIT
Todd Zullinger
Re: [PATCH 2/2] send-email: rfc2047-quote subject lines with non-ascii characters
Santi Béjar
Re: How to use git-fmt-merge-msg?
linux-netdev
:
Ramkrishna Vepa
[net-2.6 PATCH 1/10] Neterion: New driver: Driver help file
Mark Anthony
invitation / inquiry
Ingo Molnar
Re: [PATCH 08/16] dma-debug: add core checking functions
David Miller
Re: [PATCH 1/3] f_phonet: dev_kfree_skb instead of dev_kfree_skb_any in TX callback
Sascha Hauer
[PATCH 03/12] fec: do not typedef struct types
git-commits-head
:
Linux Kernel Mailing List
amba: struct device - replace bus_id with dev_name(), dev_set_name()
Linux Kernel Mailing List
MIPS: Yosemite: Convert SMP startup lock to arch spinlock.
Linux Kernel Mailing List
ARM: S5PC100: IRQ and timer
Linux Kernel Mailing List
davinci: edma: clear interrupt status for interrupt enabled channels only
Linux Kernel Mailing List
x86, mm, kprobes: fault.c, simplify notify_page_fault()
openbsd-misc
:
Daniel A. Ramaley
Re: [semi-OT] Can anyone recommend an OpenBSD-compatible colour laser printer?
Matthias Kilian
Re: can't get vesa @ 1280x800 or nv
Tobias Ulmer
Re: Problem after upgrade 4.5 to 4.6: ERR M
Philip Guenther
Re: SIGCHLD and libpthread.so
J.C. Roberts
Re: [semi-OT] Can anyone recommend an OpenBSD-compatible colour laser printer?
Colocation donated by:
Syndicate