From: "Bruno Prémont" <bonbons@linux-vserver.org>
To: linux-input@vger.kernel.org, linux-kernel@vger.kernel.org,
Jiri Kosina <jkosina@suse.cz>
Cc: Jaya Kumar <jayalk@intworks.biz>, linux-fbdev@vger.kernel.org
Subject: [PATCH 0/7] HID: picoLCD updates
Date: Mon, 30 Jul 2012 19:36:56 +0000 [thread overview]
Message-ID: <20120730213656.0a9f6d30@neptune.home> (raw)
Hi,
This series updates picoLCD driver:
- split the driver functions into separate files which get included
depending on Kconfig selection
(implementation for CIR using RC_CORE will follow later)
- drop private framebuffer refcounting in favor of refcounting added
to fb_info some time ago
- fix various bugs issues
- disabled firmware version checking in probe() as it does not work
anymore since commit 4ea5454203d991ec85264f64f89ca8855fce69b0
[HID: Fix race condition between driver core and ll-driver]
Note: I still get weird behavior on quick unbind/bind sequences
issued via sysfs (CONFIG_SMP=n system) that are triggered by framebuffer
support and apparently more specifically fb_defio part of it.
Unfortunately I'm out of ideas as to how to track down the problem which
shows either as SLAB corruption (detected with SLUB debugging, e.g.
[ 6383.521833] ======================================[ 6383.530020] BUG kmalloc-64 (Not tainted): Object already free
[ 6383.530020] -----------------------------------------------------------------------------
[ 6383.530020]
[ 6383.530020] INFO: Slab 0xdde0ea20 objectsQ used@ fp=0xcef516e0 flags=0x40000080
[ 6383.530020] INFO: Object 0xcef51190 @offset@0 fp=0xcef51f50
[ 6383.530020]
[ 6383.530020] Bytes b4 cef51180: cc cc cc cc d0 12 f5 ce 5a 5a 5a 5a 5a 5a 5a 5a ........ZZZZZZZZ
[ 6383.530020] Object cef51190: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk
[ 6383.530020] Object cef511a0: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk
[ 6383.530020] Object cef511b0: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk
[ 6383.530020] Object cef511c0: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b a5 kkkkkkkkkkkkkkk.
[ 6383.530020] Redzone cef511d0: bb bb bb bb ....
[ 6383.530020] Padding cef511d8: 5a 5a 5a 5a 5a 5a 5a 5a ZZZZZZZZ
[ 6383.530020] Pid: 1922, comm: bash Not tainted 3.5.0-jupiter-00003-g8d858b1-dirty #2
[ 6383.530020] Call Trace:
[ 6383.530020] [<c10bd3cc>] print_trailer+0x11c/0x130
[ 6383.530020] [<c10bd415>] object_err+0x35/0x40
[ 6383.530020] [<c10be809>] free_debug_processing+0x99/0x200
[ 6383.530020] [<c10bf77e>] __slab_free+0x2e/0x280
[ 6383.530020] [<c1322284>] ? hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322870>] ? __usbhid_submit_report+0xc0/0x3c0
[ 6383.530020] [<c10bfbda>] ? kfree+0xfa/0x110
[ 6383.530020] [<de932aa4>] ? picolcd_debug_out_report+0x8c4/0x8e0 [hid_picolcd]
[ 6383.530020] [<c10bfbda>] kfree+0xfa/0x110
[ 6383.530020] [<c1322284>] ? hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322284>] ? hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322284>] ? hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322284>] hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322908>] __usbhid_submit_report+0x158/0x3c0
[ 6383.530020] [<c1322c2b>] usbhid_submit_report+0x1b/0x30
[ 6383.530020] [<de930789>] picolcd_fb_reset+0xb9/0x180 [hid_picolcd]
[ 6383.530020] [<de930f1d>] picolcd_init_framebuffer+0x20d/0x2e0 [hid_picolcd]
[ 6383.530020] [<de92fb9c>] picolcd_probe+0x3cc/0x580 [hid_picolcd]
[ 6383.530020] [<c1319147>] hid_device_probe+0x67/0xf0
[ 6383.530020] [<c1282f97>] ? driver_sysfs_add+0x57/0x80
[ 6383.530020] [<c128329d>] driver_probe_device+0xbd/0x1c0
[ 6383.530020] [<c1318a1b>] ? hid_match_device+0x7b/0x90
[ 6383.530020] [<c12821e5>] driver_bind+0x75/0xd0
[ 6383.530020] [<c1282170>] ? driver_unbind+0x90/0x90
[ 6383.530020] [<c12818b7>] drv_attr_store+0x27/0x30
[ 6383.530020] [<c1114aec>] sysfs_write_file+0xac/0xf0
[ 6383.530020] [<c10c794c>] vfs_write+0x9c/0x130
[ 6383.530020] [<c10d4a1f>] ? sys_dup3+0x11f/0x160
[ 6383.530020] [<c1114a40>] ? sysfs_poll+0x90/0x90
[ 6383.530020] [<c10c7bbd>] sys_write+0x3d/0x70
[ 6383.530020] [<c13f2557>] sysenter_do_call+0x12/0x26
[ 6383.530020] FIX kmalloc-64: Object at 0xcef51190 not freed
or worse spontaneous reboot of the system without any trace on netconsole or
serial console.
echo $devid > bind; echo $devid > unbind
or
echo $devid > bind; echo $devid > unbind; sleep 0.2; echo $devid > bind; echo $devid > unbind
is sufficient to trigger the above issue while waiting a few seconds between bind and unbind
shows no sign of trouble.
Suggestions as to how to debug this and fix it are welcome!
Thanks,
Bruno
WARNING: multiple messages have this Message-ID (diff)
From: "Bruno Prémont" <bonbons@linux-vserver.org>
To: linux-input@vger.kernel.org, linux-kernel@vger.kernel.org,
Jiri Kosina <jkosina@suse.cz>
Cc: Jaya Kumar <jayalk@intworks.biz>, linux-fbdev@vger.kernel.org
Subject: [PATCH 0/7] HID: picoLCD updates
Date: Mon, 30 Jul 2012 21:36:56 +0200 [thread overview]
Message-ID: <20120730213656.0a9f6d30@neptune.home> (raw)
Hi,
This series updates picoLCD driver:
- split the driver functions into separate files which get included
depending on Kconfig selection
(implementation for CIR using RC_CORE will follow later)
- drop private framebuffer refcounting in favor of refcounting added
to fb_info some time ago
- fix various bugs issues
- disabled firmware version checking in probe() as it does not work
anymore since commit 4ea5454203d991ec85264f64f89ca8855fce69b0
[HID: Fix race condition between driver core and ll-driver]
Note: I still get weird behavior on quick unbind/bind sequences
issued via sysfs (CONFIG_SMP=n system) that are triggered by framebuffer
support and apparently more specifically fb_defio part of it.
Unfortunately I'm out of ideas as to how to track down the problem which
shows either as SLAB corruption (detected with SLUB debugging, e.g.
[ 6383.521833] =============================================================================
[ 6383.530020] BUG kmalloc-64 (Not tainted): Object already free
[ 6383.530020] -----------------------------------------------------------------------------
[ 6383.530020]
[ 6383.530020] INFO: Slab 0xdde0ea20 objects=51 used=40 fp=0xcef516e0 flags=0x40000080
[ 6383.530020] INFO: Object 0xcef51190 @offset=400 fp=0xcef51f50
[ 6383.530020]
[ 6383.530020] Bytes b4 cef51180: cc cc cc cc d0 12 f5 ce 5a 5a 5a 5a 5a 5a 5a 5a ........ZZZZZZZZ
[ 6383.530020] Object cef51190: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk
[ 6383.530020] Object cef511a0: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk
[ 6383.530020] Object cef511b0: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b kkkkkkkkkkkkkkkk
[ 6383.530020] Object cef511c0: 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b 6b a5 kkkkkkkkkkkkkkk.
[ 6383.530020] Redzone cef511d0: bb bb bb bb ....
[ 6383.530020] Padding cef511d8: 5a 5a 5a 5a 5a 5a 5a 5a ZZZZZZZZ
[ 6383.530020] Pid: 1922, comm: bash Not tainted 3.5.0-jupiter-00003-g8d858b1-dirty #2
[ 6383.530020] Call Trace:
[ 6383.530020] [<c10bd3cc>] print_trailer+0x11c/0x130
[ 6383.530020] [<c10bd415>] object_err+0x35/0x40
[ 6383.530020] [<c10be809>] free_debug_processing+0x99/0x200
[ 6383.530020] [<c10bf77e>] __slab_free+0x2e/0x280
[ 6383.530020] [<c1322284>] ? hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322870>] ? __usbhid_submit_report+0xc0/0x3c0
[ 6383.530020] [<c10bfbda>] ? kfree+0xfa/0x110
[ 6383.530020] [<de932aa4>] ? picolcd_debug_out_report+0x8c4/0x8e0 [hid_picolcd]
[ 6383.530020] [<c10bfbda>] kfree+0xfa/0x110
[ 6383.530020] [<c1322284>] ? hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322284>] ? hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322284>] ? hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322284>] hid_submit_out+0xa4/0x120
[ 6383.530020] [<c1322908>] __usbhid_submit_report+0x158/0x3c0
[ 6383.530020] [<c1322c2b>] usbhid_submit_report+0x1b/0x30
[ 6383.530020] [<de930789>] picolcd_fb_reset+0xb9/0x180 [hid_picolcd]
[ 6383.530020] [<de930f1d>] picolcd_init_framebuffer+0x20d/0x2e0 [hid_picolcd]
[ 6383.530020] [<de92fb9c>] picolcd_probe+0x3cc/0x580 [hid_picolcd]
[ 6383.530020] [<c1319147>] hid_device_probe+0x67/0xf0
[ 6383.530020] [<c1282f97>] ? driver_sysfs_add+0x57/0x80
[ 6383.530020] [<c128329d>] driver_probe_device+0xbd/0x1c0
[ 6383.530020] [<c1318a1b>] ? hid_match_device+0x7b/0x90
[ 6383.530020] [<c12821e5>] driver_bind+0x75/0xd0
[ 6383.530020] [<c1282170>] ? driver_unbind+0x90/0x90
[ 6383.530020] [<c12818b7>] drv_attr_store+0x27/0x30
[ 6383.530020] [<c1114aec>] sysfs_write_file+0xac/0xf0
[ 6383.530020] [<c10c794c>] vfs_write+0x9c/0x130
[ 6383.530020] [<c10d4a1f>] ? sys_dup3+0x11f/0x160
[ 6383.530020] [<c1114a40>] ? sysfs_poll+0x90/0x90
[ 6383.530020] [<c10c7bbd>] sys_write+0x3d/0x70
[ 6383.530020] [<c13f2557>] sysenter_do_call+0x12/0x26
[ 6383.530020] FIX kmalloc-64: Object at 0xcef51190 not freed
or worse spontaneous reboot of the system without any trace on netconsole or
serial console.
echo $devid > bind; echo $devid > unbind
or
echo $devid > bind; echo $devid > unbind; sleep 0.2; echo $devid > bind; echo $devid > unbind
is sufficient to trigger the above issue while waiting a few seconds between bind and unbind
shows no sign of trouble.
Suggestions as to how to debug this and fix it are welcome!
Thanks,
Bruno
next reply other threads:[~2012-07-30 19:36 UTC|newest]
Thread overview: 102+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-07-30 19:36 Bruno Prémont [this message]
2012-07-30 19:36 ` [PATCH 0/7] HID: picoLCD updates Bruno Prémont
2012-07-30 19:38 ` [PATCH 1/7] HID: picoLCD: split driver code Bruno Prémont
2012-07-30 19:59 ` Bruno Prémont
2012-07-30 19:59 ` Bruno Prémont
2012-07-30 19:38 ` [PATCH 2/7] HID: picoLCD: Replace own refcounting with fbdev's Bruno Prémont
2012-07-30 19:38 ` Bruno Prémont
2012-07-30 19:38 ` [PATCH 3/7] HID: picoLCD: prevent NULL pointer dereference on unplug Bruno Prémont
2012-07-30 19:38 ` Bruno Prémont
2012-07-30 19:38 ` [PATCH 4/7] HID: picoLCD: satify some checkpatch warnings Bruno Prémont
2012-07-30 19:38 ` Bruno Prémont
2012-07-30 19:38 ` [PATCH 5/7] HID: picoLCD: Improve unplug handling Bruno Prémont
2012-07-30 19:38 ` Bruno Prémont
2012-07-30 19:38 ` [PATCH 6/7] HID: picoLCD: disable version check during probe Bruno Prémont
2012-07-30 19:38 ` Bruno Prémont
2012-08-15 8:15 ` Jiri Kosina
2012-08-15 8:15 ` Jiri Kosina
2012-08-19 16:56 ` [PATCH 6/7 v2] HID: picoLCD: drop " Bruno Prémont
2012-08-19 16:56 ` Bruno Prémont
2012-08-19 16:56 ` Bruno Prémont
2012-09-17 18:21 ` Bruno Prémont
2012-09-17 18:21 ` Bruno Prémont
2012-09-17 18:21 ` Bruno Prémont
2012-09-19 11:45 ` Jiri Kosina
2012-09-19 11:45 ` Jiri Kosina
2012-09-19 11:45 ` Jiri Kosina
2012-07-30 19:39 ` [PATCH 7/7] HID: picoLCD: add myself to MAINTAINERS Bruno Prémont
2012-07-30 19:39 ` Bruno Prémont
2012-07-31 7:26 ` [PATCH 0/7] HID: picoLCD updates David Herrmann
2012-07-31 7:26 ` David Herrmann
2012-07-31 7:26 ` David Herrmann
2012-07-31 7:59 ` Bruno Prémont
2012-07-31 7:59 ` Bruno Prémont
2012-08-09 18:09 ` Bruno Prémont
2012-08-09 18:09 ` Bruno Prémont
2012-08-13 23:27 ` Tejun Heo
2012-08-13 23:27 ` Tejun Heo
2012-08-13 23:27 ` Tejun Heo
2012-08-14 6:30 ` Bruno Prémont
2012-08-14 6:30 ` Bruno Prémont
2012-08-14 6:30 ` Bruno Prémont
2012-08-14 17:31 ` Tejun Heo
2012-08-14 17:31 ` Tejun Heo
2012-08-14 17:31 ` Tejun Heo
2012-08-15 8:27 ` Jiri Kosina
2012-08-15 8:27 ` Jiri Kosina
2012-08-15 8:27 ` Jiri Kosina
2012-08-15 9:42 ` Bruno Prémont
2012-08-15 9:42 ` Bruno Prémont
2012-08-15 9:42 ` Bruno Prémont
2012-08-15 12:11 ` Jiri Kosina
2012-08-15 12:11 ` Jiri Kosina
2012-08-15 12:11 ` Jiri Kosina
2012-08-15 15:16 ` Bruno Prémont
2012-08-15 15:16 ` Bruno Prémont
2012-08-15 21:32 ` Jiri Kosina
2012-08-15 21:32 ` Jiri Kosina
2012-08-15 21:32 ` Jiri Kosina
2012-08-16 16:30 ` Bruno Prémont
2012-08-16 16:30 ` Bruno Prémont
2012-08-16 16:30 ` Bruno Prémont
2012-08-16 16:47 ` Jiri Kosina
2012-08-16 16:47 ` Jiri Kosina
2012-08-18 12:40 ` Bruno Prémont
2012-08-18 12:40 ` Bruno Prémont
2012-08-18 13:19 ` Alan Stern
2012-08-18 13:19 ` Alan Stern
2012-08-18 13:19 ` Alan Stern
2012-08-18 13:48 ` Bruno Prémont
2012-08-18 13:48 ` Bruno Prémont
2012-08-18 13:48 ` Bruno Prémont
2012-08-18 18:49 ` Bruno Prémont
2012-08-18 18:49 ` Bruno Prémont
2012-08-18 18:49 ` Bruno Prémont
2012-08-19 0:11 ` Alan Stern
2012-08-19 0:11 ` Alan Stern
2012-08-19 0:11 ` Alan Stern
2012-08-19 16:23 ` Bruno Prémont
2012-08-19 16:23 ` Bruno Prémont
2012-08-19 16:23 ` Bruno Prémont
2012-08-19 19:56 ` Alan Stern
2012-08-19 19:56 ` Alan Stern
2012-08-19 19:56 ` Alan Stern
2012-08-19 17:28 ` [PATCH 0/6] HID: picoLCD additional fixes + CIR support Bruno Prémont
2012-08-19 17:28 ` Bruno Prémont
2012-08-19 17:31 ` [PATCH 1/6] HID: picoLCD: prevent NULL pointer dereferences Bruno Prémont
2012-08-19 17:31 ` Bruno Prémont
2012-08-19 17:32 ` [PATCH 2/6] HID: picoLCD: rework hid-fbdev interaction Bruno Prémont
2012-08-19 17:32 ` Bruno Prémont
2012-08-19 17:32 ` Bruno Prémont
2012-08-19 17:32 ` [PATCH 3/6] HID: picoLCD: Add support for CIR Bruno Prémont
2012-08-19 17:32 ` Bruno Prémont
2012-09-14 14:15 ` Mauro Carvalho Chehab
2012-09-14 14:15 ` Mauro Carvalho Chehab
2012-08-19 17:33 ` [PATCH 4/6] HID: picoLCD: optimize for inactive debugfs Bruno Prémont
2012-08-19 17:33 ` Bruno Prémont
2012-08-19 17:33 ` [PATCH 5/6] HID: picoLCD: fix dumping of IR_DATA report Bruno Prémont
2012-08-19 17:33 ` Bruno Prémont
2012-08-19 17:33 ` [PATCH 6/6] HID: picoLCD: use proper device as input_dev parent Bruno Prémont
2012-08-19 17:33 ` Bruno Prémont
2012-09-05 9:50 ` [PATCH 0/6] HID: picoLCD additional fixes + CIR support Jiri Kosina
2012-09-05 9:50 ` Jiri Kosina
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20120730213656.0a9f6d30@neptune.home \
--to=bonbons@linux-vserver.org \
--cc=jayalk@intworks.biz \
--cc=jkosina@suse.cz \
--cc=linux-fbdev@vger.kernel.org \
--cc=linux-input@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.