Warning for possible circular locking dependecy on v4.16-rc1

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Geert,

When doing some testing on v4.16-rc1 I ran across this warning a couple 
of times. I was using the renesas_config from the current master branch 
of renesas-drivers at the time. It do not hit every time but in my 
limited testing I would say ~50%.


[    2.634819] ======================================================
[    2.640996] WARNING: possible circular locking dependency detected
[    2.647176] 4.16.0-rc1-arm64-renesas-00001-g75fb1624ab1a0c5a #34 Not tainted
[    2.654222] ------------------------------------------------------
[    2.660400] swapper/0/1 is trying to acquire lock:
[    2.665188]  (prepare_lock){+.+.}, at: [<        (ptrval)>] clk_prepare_lock+0x48/0xa8
[    2.673123] 
[    2.673123] but task is already holding lock:
[    2.678953]  (of_clk_mutex){+.+.}, at: [<        (ptrval)>] __of_clk_get_from_provider.part.22+0x3c/0x120
[    2.688528] 
[    2.688528] which lock already depends on the new lock.
[    2.688528] 
[    2.696706] 
[    2.696706] the existing dependency chain (in reverse order) is:
[    2.704186] 
[    2.704186] -> #5 (of_clk_mutex){+.+.}:
[    2.709511]        __mutex_lock+0x70/0x888
[    2.713606]        mutex_lock_nested+0x1c/0x28
[    2.718049]        __of_clk_get_from_provider.part.22+0x3c/0x120
[    2.724054]        of_clk_get_from_provider+0x20/0x30
[    2.729105]        cpg_mssr_attach_dev+0xfc/0x1e0
[    2.733809]        genpd_add_device+0xbc/0x230
[    2.738251]        genpd_dev_pm_attach+0xac/0x230
[    2.742954]        dev_pm_domain_attach+0xc/0x18
[    2.747571]        platform_drv_probe+0x38/0xb8
[    2.752100]        driver_probe_device+0x23c/0x310
[    2.756890]        __driver_attach+0xc4/0xc8
[    2.761157]        bus_for_each_dev+0x74/0xc8
[    2.765511]        driver_attach+0x20/0x28
[    2.769605]        bus_add_driver+0x1b0/0x220
[    2.773960]        driver_register+0x60/0xf8
[    2.778228]        __platform_driver_register+0x40/0x48
[    2.783456]        sh_mobile_i2c_adap_init+0x18/0x20
[    2.788423]        do_one_initcall+0x9c/0x14c
[    2.792778]        kernel_init_freeable+0x1dc/0x274
[    2.797654]        kernel_init+0x10/0x100
[    2.801665]        ret_from_fork+0x10/0x18
[    2.805757] 
[    2.805757] -> #4 (&genpd->mlock){+.+.}:
[    2.811162]        __mutex_lock+0x70/0x888
[    2.815256]        mutex_lock_nested+0x1c/0x28
[    2.819699]        genpd_lock_mtx+0x14/0x20
[    2.823879]        genpd_runtime_resume+0x70/0x230
[    2.828667]        __rpm_callback+0xe0/0x268
[    2.832934]        rpm_callback+0x20/0x80
[    2.836940]        rpm_resume+0x344/0x608
[    2.840946]        __pm_runtime_resume+0x50/0x78
[    2.845561]        usb_dmac_alloc_chan_resources+0x8c/0xa0
[    2.851044]        dma_chan_get+0x28/0x80
[    2.855051]        find_candidate+0xf8/0x188
[    2.859319]        __dma_request_channel+0x68/0xc8
[    2.864108]        usb_dmac_of_xlate+0x64/0x98
[    2.868550]        of_dma_request_slave_channel+0x170/0x270
[    2.874121]        dma_request_chan+0x38/0x1d0
[    2.878568]        usbhsf_dma_init.isra.8+0x60/0x108
[    2.883531]        usbhs_fifo_probe+0x70/0x148
[    2.887972]        usbhs_probe+0x2c8/0x5e0
[    2.892065]        platform_drv_probe+0x58/0xb8
[    2.896594]        driver_probe_device+0x23c/0x310
[    2.901382]        __driver_attach+0xc4/0xc8
[    2.905649]        bus_for_each_dev+0x74/0xc8
[    2.910004]        driver_attach+0x20/0x28
[    2.914097]        bus_add_driver+0x1b0/0x220
[    2.918452]        driver_register+0x60/0xf8
[    2.922718]        __platform_driver_register+0x40/0x48
[    2.927942]        renesas_usbhs_driver_init+0x18/0x20
[    2.933078]        do_one_initcall+0x9c/0x14c
[    2.937433]        kernel_init_freeable+0x1dc/0x274
[    2.942309]        kernel_init+0x10/0x100
[    2.946316]        ret_from_fork+0x10/0x18
[    2.950407] 
[    2.950407] -> #3 (dma_list_mutex){+.+.}:
[    2.955900]        __mutex_lock+0x70/0x888
[    2.959994]        mutex_lock_nested+0x1c/0x28
[    2.964435]        __dma_request_channel+0x38/0xc8
[    2.969225]        usb_dmac_of_xlate+0x64/0x98
[    2.973666]        of_dma_request_slave_channel+0x170/0x270
[    2.979236]        dma_request_chan+0x38/0x1d0
[    2.983678]        usbhsf_dma_init.isra.8+0x60/0x108
[    2.988640]        usbhs_fifo_probe+0x70/0x148
[    2.993081]        usbhs_probe+0x2c8/0x5e0
[    2.997174]        platform_drv_probe+0x58/0xb8
[    3.001702]        driver_probe_device+0x23c/0x310
[    3.006491]        __driver_attach+0xc4/0xc8
[    3.010759]        bus_for_each_dev+0x74/0xc8
[    3.015114]        driver_attach+0x20/0x28
[    3.019208]        bus_add_driver+0x1b0/0x220
[    3.023562]        driver_register+0x60/0xf8
[    3.027829]        __platform_driver_register+0x40/0x48
[    3.033052]        renesas_usbhs_driver_init+0x18/0x20
[    3.038188]        do_one_initcall+0x9c/0x14c
[    3.042543]        kernel_init_freeable+0x1dc/0x274
[    3.047419]        kernel_init+0x10/0x100
[    3.051426]        ret_from_fork+0x10/0x18
[    3.055517] 
[    3.055517] -> #2 (of_dma_lock){+.+.}:
[    3.060749]        __mutex_lock+0x70/0x888
[    3.064843]        mutex_lock_nested+0x1c/0x28
[    3.069284]        of_dma_request_slave_channel+0x12c/0x270
[    3.074855]        dma_request_chan+0x38/0x1d0
[    3.079300]        rcar_i2c_master_xfer+0x1b4/0x458
[    3.084176]        __i2c_transfer+0x11c/0x260
[    3.088530]        i2c_transfer+0x60/0xc8
[    3.092537]        i2c_smbus_xfer_emulated+0x14c/0x5d0
[    3.097673]        i2c_smbus_xfer+0x128/0x1a0
[    3.102027]        i2c_smbus_read_byte_data+0x40/0x70
[    3.107076]        cs2000_bset.isra.1+0x2c/0x68
[    3.111604]        __cs2000_set_rate.constprop.7+0x80/0x148
[    3.117174]        cs2000_probe+0xd4/0x260
[    3.121267]        i2c_device_probe+0x2a4/0x2c8
[    3.125796]        driver_probe_device+0x23c/0x310
[    3.130584]        __device_attach_driver+0x94/0xd8
[    3.135460]        bus_for_each_drv+0x68/0xd0
[    3.139813]        __device_attach+0xd8/0x138
[    3.144168]        device_initial_probe+0x10/0x18
[    3.148870]        bus_probe_device+0x94/0xa0
[    3.153224]        device_add+0x3b8/0x5e0
[    3.157230]        device_register+0x1c/0x28
[    3.161497]        i2c_new_device+0x138/0x338
[    3.165852]        of_i2c_register_device+0x114/0x1e8
[    3.170900]        of_i2c_register_devices+0x7c/0xf8
[    3.175862]        i2c_register_adapter+0x160/0x418
[    3.180737]        __i2c_add_numbered_adapter+0x60/0x98
[    3.185959]        i2c_add_adapter+0xa4/0xd0
[    3.190227]        i2c_add_numbered_adapter+0x24/0x30
[    3.195276]        rcar_i2c_probe+0x330/0x418
[    3.199629]        platform_drv_probe+0x58/0xb8
[    3.204157]        driver_probe_device+0x23c/0x310
[    3.208946]        __driver_attach+0xc4/0xc8
[    3.213213]        bus_for_each_dev+0x74/0xc8
[    3.217567]        driver_attach+0x20/0x28
[    3.221661]        bus_add_driver+0x1b0/0x220
[    3.226015]        driver_register+0x60/0xf8
[    3.230282]        __platform_driver_register+0x40/0x48
[    3.235505]        rcar_i2c_driver_init+0x18/0x20
[    3.240207]        do_one_initcall+0x9c/0x14c
[    3.244561]        kernel_init_freeable+0x1dc/0x274
[    3.249437]        kernel_init+0x10/0x100
[    3.253444]        ret_from_fork+0x10/0x18
[    3.257536] 
[    3.257536] -> #1 (i2c_register_adapter){+.+.}:
[    3.263549]        rt_mutex_lock+0x30/0x50
[    3.267642]        i2c_adapter_lock_bus+0x10/0x18
[    3.272343]        i2c_transfer+0xa8/0xc8
[    3.276350]        i2c_smbus_xfer_emulated+0x14c/0x5d0
[    3.281486]        i2c_smbus_xfer+0x128/0x1a0
[    3.285840]        i2c_smbus_read_byte_data+0x40/0x70
[    3.290889]        cs2000_recalc_rate+0x38/0x90
[    3.295417]        clk_register+0x390/0x6e0
[    3.299598]        clk_hw_register+0xc/0x20
[    3.303778]        cs2000_probe+0x134/0x260
[    3.307957]        i2c_device_probe+0x2a4/0x2c8
[    3.312485]        driver_probe_device+0x23c/0x310
[    3.317274]        __device_attach_driver+0x94/0xd8
[    3.322150]        bus_for_each_drv+0x68/0xd0
[    3.326504]        __device_attach+0xd8/0x138
[    3.330858]        device_initial_probe+0x10/0x18
[    3.335560]        bus_probe_device+0x94/0xa0
[    3.339913]        device_add+0x3b8/0x5e0
[    3.343919]        device_register+0x1c/0x28
[    3.348186]        i2c_new_device+0x138/0x338
[    3.352540]        of_i2c_register_device+0x114/0x1e8
[    3.357589]        of_i2c_register_devices+0x7c/0xf8
[    3.362551]        i2c_register_adapter+0x160/0x418
[    3.367426]        __i2c_add_numbered_adapter+0x60/0x98
[    3.372648]        i2c_add_adapter+0xa4/0xd0
[    3.376915]        i2c_add_numbered_adapter+0x24/0x30
[    3.381964]        rcar_i2c_probe+0x330/0x418
[    3.386318]        platform_drv_probe+0x58/0xb8
[    3.390846]        driver_probe_device+0x23c/0x310
[    3.395634]        __driver_attach+0xc4/0xc8
[    3.399902]        bus_for_each_dev+0x74/0xc8
[    3.404256]        driver_attach+0x20/0x28
[    3.408350]        bus_add_driver+0x1b0/0x220
[    3.412704]        driver_register+0x60/0xf8
[    3.416971]        __platform_driver_register+0x40/0x48
[    3.422194]        rcar_i2c_driver_init+0x18/0x20
[    3.426896]        do_one_initcall+0x9c/0x14c
[    3.431250]        kernel_init_freeable+0x1dc/0x274
[    3.436126]        kernel_init+0x10/0x100
[    3.440132]        ret_from_fork+0x10/0x18
[    3.444224] 
[    3.444224] -> #0 (prepare_lock){+.+.}:
[    3.449544]        lock_acquire+0x48/0x68
[    3.453551]        __mutex_lock+0x70/0x888
[    3.457645]        mutex_lock_nested+0x1c/0x28
[    3.462086]        clk_prepare_lock+0x48/0xa8
[    3.466440]        __clk_create_clk.part.20+0x64/0xa0
[    3.471489]        __of_clk_get_from_provider.part.22+0xd0/0x120
[    3.477494]        __of_clk_get_from_provider+0x10/0x20
[    3.482717]        __of_clk_get_by_name+0x9c/0x158
[    3.487505]        clk_get+0x2c/0x78
[    3.491078]        devm_clk_get+0x4c/0xa8
[    3.495090]        rsnd_dvc_probe+0x15c/0x210
[    3.499444]        rsnd_probe+0xcc/0x480
[    3.503363]        platform_drv_probe+0x58/0xb8
[    3.507891]        driver_probe_device+0x23c/0x310
[    3.512680]        __driver_attach+0xc4/0xc8
[    3.516947]        bus_for_each_dev+0x74/0xc8
[    3.521301]        driver_attach+0x20/0x28
[    3.525395]        bus_add_driver+0x1b0/0x220
[    3.529749]        driver_register+0x60/0xf8
[    3.534016]        __platform_driver_register+0x40/0x48
[    3.539240]        rsnd_driver_init+0x18/0x20
[    3.543595]        do_one_initcall+0x9c/0x14c
[    3.547949]        kernel_init_freeable+0x1dc/0x274
[    3.552825]        kernel_init+0x10/0x100
[    3.556832]        ret_from_fork+0x10/0x18
[    3.560924] 
[    3.560924] other info that might help us debug this:
[    3.560924] 
[    3.568928] Chain exists of:
[    3.568928]   prepare_lock --> &genpd->mlock --> of_clk_mutex
[    3.568928] 
[    3.579026]  Possible unsafe locking scenario:
[    3.579026] 
[    3.584943]        CPU0                    CPU1
[    3.589469]        ----                    ----
[    3.593995]   lock(of_clk_mutex);
[    3.597309]                                lock(&genpd->mlock);
[    3.603228]                                lock(of_clk_mutex);
[    3.609060]   lock(prepare_lock);
[    3.612374] 
[    3.612374]  *** DEADLOCK ***
[    3.612374] 
[    3.618294] 3 locks held by swapper/0/1:
[    3.622212]  #0:  (&dev->mutex){....}, at: [<        (ptrval)>] __driver_attach+0x4c/0xc8
[    3.630397]  #1:  (&dev->mutex){....}, at: [<        (ptrval)>] __driver_attach+0x5c/0xc8
[    3.638581]  #2:  (of_clk_mutex){+.+.}, at: [<        (ptrval)>] __of_clk_get_from_provider.part.22+0x3c/0x120
[    3.648589] 
[    3.648589] stack backtrace:
[    3.652946] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 4.16.0-rc1-arm64-renesas-00001-g75fb1624ab1a0c5a #34
[    3.662599] Hardware name: Renesas Salvator-X 2nd version board based on r8a7795 ES2.0+ (DT)
[    3.671036] Call trace:
[    3.673481]  dump_backtrace+0x0/0x1c8
[    3.677142]  show_stack+0x14/0x20
[    3.680455]  dump_stack+0xbc/0xf8
[    3.683767]  print_circular_bug.isra.19+0x1d4/0x2e0
[    3.688642]  __lock_acquire+0x15ec/0x1890
[    3.692648]  lock_acquire+0x48/0x68
[    3.696134]  __mutex_lock+0x70/0x888
[    3.699707]  mutex_lock_nested+0x1c/0x28
[    3.703626]  clk_prepare_lock+0x48/0xa8
[    3.707459]  __clk_create_clk.part.20+0x64/0xa0
[    3.711987]  __of_clk_get_from_provider.part.22+0xd0/0x120
[    3.717471]  __of_clk_get_from_provider+0x10/0x20
[    3.722172]  __of_clk_get_by_name+0x9c/0x158
[    3.726439]  clk_get+0x2c/0x78
[    3.729490]  devm_clk_get+0x4c/0xa8
[    3.732976]  rsnd_dvc_probe+0x15c/0x210
[    3.736808]  rsnd_probe+0xcc/0x480
[    3.740207]  platform_drv_probe+0x58/0xb8
[    3.744213]  driver_probe_device+0x23c/0x310
[    3.748481]  __driver_attach+0xc4/0xc8
[    3.752227]  bus_for_each_dev+0x74/0xc8
[    3.756061]  driver_attach+0x20/0x28
[    3.759633]  bus_add_driver+0x1b0/0x220
[    3.763466]  driver_register+0x60/0xf8
[    3.767212]  __platform_driver_register+0x40/0x48
[    3.771913]  rsnd_driver_init+0x18/0x20
[    3.775747]  do_one_initcall+0x9c/0x14c
[    3.779580]  kernel_init_freeable+0x1dc/0x274
[    3.783934]  kernel_init+0x10/0x100
[    3.787419]  ret_from_fork+0x10/0x18

-- 
Regards,
Niklas Söderlund



[Index of Archives]     [Linux Samsung SOC]     [Linux Wireless]     [Linux Kernel]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Samba]     [Device Mapper]

  Powered by Linux