Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752496AbcLHIk5 (ORCPT ); Thu, 8 Dec 2016 03:40:57 -0500 Received: from mailout4.w1.samsung.com ([210.118.77.14]:47922 "EHLO mailout4.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750729AbcLHIky (ORCPT ); Thu, 8 Dec 2016 03:40:54 -0500 MIME-version: 1.0 Content-type: text/plain; charset=utf-8; format=flowed X-AuditID: cbfec7f4-f791c6d000006eac-a2-58491c911160 Subject: Re: [BUG 4.9] New led trigger usbport gets the kernel to panic To: =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= , Pavel Machek Cc: Ralph Sennhauser , "open list:LED SUBSYSTEM" , Richard Purdie , =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= , Greg Kroah-Hartman , "linux-usb@vger.kernel.org" , Linux Kernel Mailing List From: Jacek Anaszewski Message-id: <6c5ea183-4ef8-7524-034d-69fb388a3a7a@samsung.com> Date: Thu, 08 Dec 2016 09:40:43 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.2.0 In-reply-to: Content-transfer-encoding: 8bit X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFprHKsWRmVeSWpSXmKPExsWy7djPc7oTZTwjDJbuNLNoXryezeLyrjls FlvfrGO0WLSsldni7qmjbBa71y5isjh/6TCjxe5dT1kt1pxMdeD02DnrLrvH/rlr2D3OT/X0 2DP/B6vHitXf2T0+b5ILYIvisklJzcksSy3St0vgyvhyibtgn2rF+S1v2RsYH8l3MXJySAiY SHTf284MYYtJXLi3nq2LkYtDSGApo8SPH/uZIZzPjBL7bzxmg+nYsX0zVNUyRoldl7eCJXgF BCV+TL7HAmIzC1hJPPvXygpR9IxRYuvdDlaQhLCAu0THhEtgtohAmMSLZa1MIEXMAh+YJA5O +gTWzSZgKPHzxWsmiKl2EvuntYLZLAKqEjuanwLZHByiAhESu++mgoQ5BYIlfrXtYIVYLC9x 8MpzFpCZEgK72CX2vJ/HBlIvISArsekA1J8uErdfzYayhSVeHd/CDmHLSFye3A3VO5lR4uKx m6wQzmpGiY2dnSwQVdYSDf9/Qb3JJzFp23RmiAW8Eh1tQhAlHhIvtq2GGuooMXfzBzBbSGAW s8TTNpUJjPKzkAJsFlKAzULywwJG5lWMIqmlxbnpqcUmesWJucWleel6yfm5mxiBqeb0v+Nf djAuPmZ1iFGAg1GJh9dB3iNCiDWxrLgy9xCjBAezkgjvfinPCCHelMTKqtSi/Pii0pzU4kOM 0hwsSuK8exZcCRcSSE8sSc1OTS1ILYLJMnFwSjUwdqyZV/TvbsVB+TUZh1SkhRTWbFUwE3ZO 3r/EKO9Xm4rF0dnFdgY+P56s7Vl3IkKx6m1MzbXOlg2VOkt/xvFP1JjSwc9y2HqBsd+TAu70 +LW739RJVf84+OCEQcYx20m/s/omBD2oPnj+rESg8ZV/Tw4cyr2yy7zecMPDww9sUiY/+Dt1 +oPws0osxRmJhlrMRcWJAKf9fUoxAwAA X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFtrPIsWRmVeSWpSXmKPExsVy+t/xK7q1Mp4RBpv7NCyaF69ns7i8aw6b xdY36xgtFi1rZba4e+oom8XutYuYLM5fOsxosXvXU1aLNSdTHTg9ds66y+6xf+4ado/zUz09 9sz/weqxYvV3do/Pm+QC2KLcbDJSE1NSixRS85LzUzLz0m2VQkPcdC2UFPISc1NtlSJ0fUOC lBTKEnNKgTwjAzTg4BzgHqykb5fglvHlEnfBPtWK81vesjcwPpLvYuTkkBAwkdixfTMbhC0m ceHeeiCbi0NIYAmjxPLXD1hAErwCghI/Jt8Ds5kFzCS+vDzMClH0jFHi0vHZTCAJYQF3iY4J l1hBbBGBMImD0/uYIIpmMUs8PrCUEcRhFvjEJHHo4CewfWwChhI/X7xmglhhJ7F/WiuYzSKg KrGj+SmYLSoQIXFr1UdGEJtTIFji/5k9zBBnyEscvPKcZQKjwCwkF85CcuEsJGULGJlXMYqk lhbnpucWG+kVJ+YWl+al6yXn525iBEbetmM/t+xg7HoXfIhRgINRiYfXQd4jQog1say4MvcQ owQHs5II734pzwgh3pTEyqrUovz4otKc1OJDjKZAx05klhJNzgcmhbySeEMTQ3NLQyNjCwtz IyMlcd6pH66ECwmkJ5akZqemFqQWwfQxcXBKNTBeW8ho5LC9eifPZ4bvIeI9y25/PLm9fKdN 7zeVFlvVd49VZvJv0L4rsOa2s941JfPcxj8BPztrYt3Vqtheb9aV717E7SOw/GR2xe6iM6WP N+xpit5p5KGz/kpJuu/fv7MSXIPUPESuqscnzv04+62j+3+bcq89XL5TN9Zb73ue8eyxzI4L B9uVWIozEg21mIuKEwFpSg940gIAAA== X-MTR: 20000000000000000@CPGS X-CMS-MailID: 20161208084049eucas1p2dad402150eff387f99eda6238a807ffa X-Msg-Generator: CA X-Sender-IP: 182.198.249.180 X-Local-Sender: =?UTF-8?B?SmFjZWsgQW5hc3pld3NraRtTUlBPTC1TeXN0ZW0gRlcgIChN?= =?UTF-8?B?Qikb7IK87ISx7KCE7J6QG1NlbmlvciBTb2Z0d2FyZSBFbmdpbmVlcg==?= X-Global-Sender: =?UTF-8?B?SmFjZWsgQW5hc3pld3NraRtTUlBPTC1TeXN0ZW0gRlcgIChN?= =?UTF-8?B?QikbU2Ftc3VuZyBFbGVjdHJvbmljcxtTZW5pb3IgU29mdHdhcmUgRW5naW5l?= =?UTF-8?B?ZXI=?= X-Sender-Code: =?UTF-8?B?QzEwG0VIURtDMTBDRDAyQ0QwMjc1MjY=?= CMS-TYPE: 201P X-HopCount: 7 X-CMS-RootMailID: 20161206173007epcas2p23440ee22a8b8c17d27f18774e20239d1 X-RootMTR: 20161206173007epcas2p23440ee22a8b8c17d27f18774e20239d1 References: <20161121094022.30478a37@gmail.com> <43ea90fb-780a-3612-77dd-265e877ac18e@milecki.pl> <20161201152825.3b2686db@gmail.com> <20161202094818.6b9c1ed2@gmail.com> <20161206172619.GB4406@amd> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 4690 Lines: 108 Hi Rafał, On 12/06/2016 06:29 PM, Rafał Miłecki wrote: > On 6 December 2016 at 18:26, Pavel Machek wrote: >> On Fri 2016-12-02 09:48:18, Ralph Sennhauser wrote: >>> On Thu, 1 Dec 2016 17:56:07 +0100 >>> Rafał Miłecki wrote: >>> >>>> On 12/01/2016 03:28 PM, Ralph Sennhauser wrote: >>>>> Below the oops with your debug patch applied. >>>>> >>>>> (...) >>>>> >>>>> root@wrt1900acs:/# cd sys/class/leds/pca963x\:shelby\:white\:usb2/ >>>>> root@wrt1900acs:/sys/devices/platform/soc/soc:internal-regs/f1011000.i2c/i2c-0/0-0068/leds/pca963x:shelby:white:usb2# >>>>> echo usbport > trigger [ 124.727665] leds >>>>> pca963x:shelby:white:usb2: [usbport_trig_add_port] port:dd708240 >>>>> [ 124.735266] leds pca963x:shelby:white:usb2: >>>>> [usbport_trig_add_port] port->port_name:usb1-port1 >>>>> port->data:dd708140 [ 124.745671] leds pca963x:shelby:white:usb2: >>>>> [usbport_trig_add_port] port:dd7083c0 [ 124.753194] leds >>>>> pca963x:shelby:white:usb2: [usbport_trig_add_port] >>>>> port->port_name:usb2-port1 port->data:dd708140 [ 124.763594] leds >>>>> pca963x:shelby:white:usb2: [usbport_trig_add_port] port:dd708300 >>>>> [ 124.771114] leds pca963x:shelby:white:usb2: >>>>> [usbport_trig_add_port] port->port_name:usb3-port1 >>>>> port->data:dd708140 >>>>> root@wrt1900acs:/sys/devices/platform/soc/soc:internal-regs/f1011000.i2c/i2c-0/0-0068/leds/pca963x:shelby:white:usb2# >>>>> echo 1 > ports/usb2-port1[ 171.649751] leds >>>>> pca963x:shelby:white:usb2: [usbport_trig_port_store] buf:1 >>>>> [ 171.649751] size:2 >>>>> >>>>> [ 171.660160] leds pca963x:shelby:white:usb2: >>>>> [usbport_trig_port_store] port:dd7083c0 [ 171.668103] leds >>>>> pca963x:shelby:white:usb2: [usbport_trig_port_store] >>>>> port->port_name:usb2-port1 port->data:dd708140 [ 171.678678] >>>>> [usbport_trig_update_count] usbport_data->count:0 [ 171.684457] >>>>> [usbport_trig_update_count] usbport_data->count:0 [ 171.690253] >>>>> Unable to handle kernel NULL pointer dereference at virtual address >>>>> 00000000 >>>> >>>> Oh, so this happens a bit later than I expected or I could read from >>>> the backtrace. Anyway this debugging was still helpful, I think I can >>>> see a possible problem. >>>> >>>> So most likely the crash happens at the: >>>> led_cdev->brightness_set(led_cdev, ...); >>>> call. I'm not sure what I was thinking when writing that code. It >>>> looks wrong. >>>> >>>> The thing is some LEDs (drivers) don't provide brightness_set op. >>>> It's fine, we should just use brightness_set_blocking op when that >>>> happens. Of course kernel has proper helpers for that, we don't have >>>> to worry about the choice of op or scheduling the work. I have no >>>> idea why I didn't use a proper helper in the first place. >>>> >>>> So we should simply replace above call with one of following ones: >>>> 1) led_set_brightness(led_cdev, ...); >>>> 2) led_set_brightness_nosleep(led_cdev, ...); >>>> 3) led_set_brightness_sync(led_cdev, ...); >>>> >>>> I still have to check which one is correct. In theory we don't deal >>>> blinking at this point so we shouldn't need to use led_set_brightness. >>>> >>>> led_set_brightness_nosleep looks like the most likely correct choice. >>>> >>>> led_set_brightness_sync requires brightness_set_blocking which is not >>>> always present so most likely we don't want this one. >>>> >>>> >>>> If you have some free time and you want to play with this, please >>>> replace led_cdev->brightness_set >>>> with >>>> led_set_brightness_nosleep >>>> and give it a try. This should fix crashes for you. >>>> >>>> I'll look at this again during next days. >>> >>> Hi Rafał >>> >>> I just gave 2) led_set_brightness_nosleep a try. The kernel no longer >>> crashes and the led does work as expected. >> >> Do you have any patch that needs to be applied? > > Yes, it has been pushed: > https://git.kernel.org/cgit/linux/kernel/git/gregkh/usb.git/commit/?h=usb-next&id=89778ba335e302a450932ce5b703c1ee6216e949 > > When sending it I didn't Cc linux-leds as get_maintainer.pl didn't > pick it. Should we add MAINTAINERS entry for ledtrig-usbport.c maybe? > I haven't tested this trigger earlier, probably due to the fact that it was targeted for usb subsystem, sorry about that. Nonetheless, I've just tried it on exynos4412-trats2 board and it seems not to work properly. I have the board connected through USB (I have an opened ssh session), I'm doing "echo usbport > trigger", then I can see the "ports" directory, but it is empty. Any ideas on the possible reasons? Exynos4412-trats2 uses Ethernet Gadget (with CDC Ethernet support) USB Gadget Driver for USB networking. -- Best regards, Jacek Anaszewski