Hi Jean, > On Jan 14, 2015, at 15:49 , Jean Delvare <jdelvare@xxxxxxx> wrote: > > Hi Wolfram, Pantelis, > > On Tue, 13 Jan 2015 16:29:57 +0100, Wolfram Sang wrote: >> On Mon, Jan 12, 2015 at 07:00:50PM +0200, Pantelis Antoniou wrote: >>> Waiting for the device release method to be called when >>> going through i2c_del_adapter is wrong and leads to deadlock >>> when removing an i2c mux device. >> >> Adding Jean to the list, maybe he knows more details from the past. >> >>> For instance when using the OF i2c mux unitest removal we get this. > > I can't parse the sentence above, sorry. What is "unitest”? > The DT overlay patchset contains a number of OF unitests for its features. One of the new tests is performing a runtime insertion and removal of an i2c mux containing an i2c device on one of the channels. When removing the mux device we get a deadlock. >>> [<c055dfdc>] (__schedule) from [<c0561b74>] (schedule_timeout+0x18/0x198) >>> [<c0561b74>] (schedule_timeout) from [<c055ee74>] (wait_for_common+0xf8/0x138) >>> [<c055ee74>] (wait_for_common) from [<c03f724c>] (i2c_del_adapter+0x174/0x1cc) >>> [<c03f724c>] (i2c_del_adapter) from [<c03f8480>] (i2c_del_mux_adapter+0x48/0x60) >>> [<c03f8480>] (i2c_del_mux_adapter) from [<c046cf00>] (selftest_i2c_mux_remove+0x28/0x34) >>> [<c046cf00>] (selftest_i2c_mux_remove) from [<c03f5234>] (i2c_device_remove+0x34/0x70) >>> [<c03f5234>] (i2c_device_remove) from [<c03322ec>] (__device_release_driver+0x7c/0xc0) >>> [<c03322ec>] (__device_release_driver) from [<c0332968>] (driver_detach+0x8c/0xb4) >>> [<c0332968>] (driver_detach) from [<c0332088>] (bus_remove_driver+0x64/0x8c) >>> [<c0332088>] (bus_remove_driver) from [<c07f1858>] (of_selftest+0x1f84/0x20f0) >>> [<c07f1858>] (of_selftest) from [<c0008b04>] (do_one_initcall+0x104/0x1b4) >>> [<c0008b04>] (do_one_initcall) from [<c07c4d9c>] (kernel_init_freeable+0x110/0x1d8) >>> [<c07c4d9c>] (kernel_init_freeable) from [<c05591ec>] (kernel_init+0x8/0xe4) >>> [<c05591ec>] (kernel_init) from [<c000deb8>] (ret_from_fork+0x14/0x3c) >>> 2 locks held by swapper/0/1: >>> #0: (&dev->mutex){......}, at: [<c0332944>] driver_detach+0x68/0xb4 >>> #1: (&dev->mutex){......}, at: [<c0332954>] driver_detach+0x78/0xb4 >>> Kernel panic - not syncing: hung_task: blocked tasks >>> CPU: 0 PID: 16 Comm: khungtaskd Not tainted 3.19.0-rc4-00022-g261647c #443 >>> Hardware name: Generic AM33XX (Flattened Device Tree) >>> [<c00140a8>] (unwind_backtrace) from [<c00110dc>] (show_stack+0x10/0x14) >>> [<c00110dc>] (show_stack) from [<c055c3ac>] (dump_stack+0x70/0x8c) >>> [<c055c3ac>] (dump_stack) from [<c055ad10>] (panic+0x88/0x1f0) >>> [<c055ad10>] (panic) from [<c00adef8>] (watchdog+0x2d4/0x350) >>> [<c00adef8>] (watchdog) from [<c004e984>] (kthread+0xd8/0xec) >>> [<c004e984>] (kthread) from [<c000deb8>] (ret_from_fork+0x14/0x3c) >>> >>> The device release method is never called and we hang waiting for it. >>> >>> This patch is marked as an [RFC] since the original code seems to >>> really want to protect against a race from sysfs accessors, which >>> I don't see how it could be a problem. > > The code is not from me, it's from Greg KH. It was written in August > 2003 when Greg converted the i2c subsystem to somewhat fit into the > (then) new device driver model. So that was a long time ago and it is > possible that this is no longer necessary. FWIW I can't see anything > similar in other subsystems. > > In fact I'm not sure what purpose the completion serves exactly. I > expected it to delay the i2c adapter removal until no sysfs user of it > was left (as the comment suggests.) However I just tested unloading an > i2c bus driver while its adapter's new_device attribute was opened and > rmmod returned immediately. So it doesn't look like accessing sysfs > attributes actually takes a reference to the underlying i2c_adapter. > That’s what got me stumped too. I haven’t seen something like this before. > That being said, nobody complained about this in 11 years, so I would > be surprised if it was plain wrong. I'd rather question the test code. > Where is it? > No-one has apparently tested removing an i2c mux device on a running system before. It’s in a new patchset I posted earlier. Search for "of: unitest: Add I2C overlay unit tests.” https://www.mail-archive.com/devicetree@xxxxxxxxxxxxxxx/msg57577.html > -- > Jean Delvare > SUSE L3 Support Regards — Pantelis -- To unsubscribe from this list: send the line "unsubscribe linux-i2c" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html