px30-evb crash on 6.0.0-rc6, u2phy_otg, otg-port issue

Mikhail Rudenko mike.rudenko at gmail.com
Fri Sep 23 09:48:34 PDT 2022


Hi Tommaso,

On 2022-09-23 at 17:20 +02, Tommaso Merciai <tommaso.merciai at amarulasolutions.com> wrote:

> Hello Heiko,
> I'm playing with px30_mini_evb_v11_20190507 board on linux 6.0.0-rc6.
> We have some problems on "rockchip,px30-usb2phy" driver in particular in
> u2phy_otg: otg-port node (px30-evb.dts). Disabling this I'm able to boot
> the board:
>
> &u2phy {
> 	status = "okay";
>
> 	u2phy_host: host-port {
> 		status = "okay";
> 	};
>
> 	u2phy_otg: otg-port {
> 		status = "disabled";
> 	};
> };
>
> In particular we have some problems here:
>
> diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c
> index bd0b35cac83e3..42647cd660bbf 100644
> --- a/drivers/clk/clk.c
> +++ b/drivers/clk/clk.c
> @@ -4084,7 +4084,9 @@ static int clk_nodrv_prepare_enable(struct clk_hw *hw)
>
> static void clk_nodrv_disable_unprepare(struct clk_hw *hw)
> {
>       WARN_ON_ONCE(1);
> }
>
> logs:
>
> [    1.269466] rockchip-usb2phy: probe of ff2c0000.syscon:usb2phy at 100 failed with error 1
> [    1.279044] ------------[ cut here ]------------
> [    1.284135] WARNING: CPU: 0 PID: 1 at drivers/clk/clk.c:4087 clk_nodrv_disable_unprepare+0x4/0x10
> [    1.293913] Modules linked in:
> [    1.297276] CPU: 0 PID: 1 Comm: swapper/0 Not tainted 6.0.0-rc6-00220-gb82580766e4c #147
> [    1.306172] Hardware name: Rockchip PX30 EVB (DT)
> [    1.311338] pstate: 600000c5 (nZCv daIF -PAN -UAO -TCO -DIT -SSBS BTYPE=--)
> [    1.318993] pc : clk_nodrv_disable_unprepare+0x4/0x10
> [    1.324549] lr : clk_core_disable+0x60/0xb8
> [    1.329152] sp : ffff80000a5eba20
> [    1.332793] x29: ffff80000a5eba20 x28: 0000000000000007 x27: ffff800009b96068
> [    1.340657] x26: ffff800009ad0400 x25: ffff80000a52b000 x24: 0000000000000000
> [    1.348516] x23: ffff0000038f5300 x22: 0000000000000000 x21: 0000000000000000
> [    1.356376] x20: ffff0000038f5300 x19: ffff0000038f5300 x18: ffff000002c76610
> [    1.364240] x17: 000000005a2f9018 x16: 000000008b35b0bc x15: ffff000003097740
> [    1.372100] x14: 0000000000000000 x13: ffff000002c76610 x12: ffff0000030976c0
> [    1.379961] x11: 000000ffffffffff x10: ffff000002c76618 x9 : ffff000002c76610
> [    1.387822] x8 : ffff0000038f5300 x7 : ffff000002ce0000 x6 : 0000000000000000
> [    1.395683] x5 : 0000000000000000 x4 : 0000000000000000 x3 : ffff80000a592748
> [    1.403545] x2 : 0000000000000001 x1 : ffff8000086d7c88 x0 : ffff00000366f8a8
> [    1.411407] Call trace:
> [    1.414091]  clk_nodrv_disable_unprepare+0x4/0x10
> [    1.419269]  clk_core_disable_lock+0x24/0x40
> [    1.423967]  clk_core_disable_unprepare+0x18/0x38
> [    1.429145]  __clk_set_parent_after+0x60/0x68
> [    1.433940]  clk_core_set_parent_nolock+0x160/0x250
> [    1.439311]  clk_unregister+0xe4/0x240
> [    1.443443]  rockchip_usb2phy_clk480m_unregister+0x28/0x38
> [    1.449482]  devm_action_release+0x14/0x20
> [    1.453996]  release_nodes+0x40/0x70
> [    1.457934]  devres_release_all+0x94/0xe0
> [    1.462344]  device_unbind_cleanup+0x18/0x68
> [    1.467043]  really_probe+0x1d0/0x2b8
> [    1.471070]  __driver_probe_device+0x7c/0xe8
> [    1.475771]  driver_probe_device+0x38/0x100
> [    1.480373]  __driver_attach+0xa8/0x138
> [    1.484595]  bus_for_each_dev+0x7c/0xd8
> [    1.488816]  driver_attach+0x24/0x30
> [    1.492750]  bus_add_driver+0x15c/0x210
> [    1.496968]  driver_register+0x64/0x120
> [    1.501190]  __platform_driver_register+0x28/0x38
> [    1.506367]  rockchip_usb2phy_driver_init+0x1c/0x28
> [    1.511733]  do_one_initcall+0x60/0x1f0
> [    1.515957]  kernel_init_freeable+0x22c/0x2a0
> [    1.520757]  kernel_init+0x24/0x130
> [    1.524604]  ret_from_fork+0x10/0x20
> [    1.528539] ---[ end trace 0000000000000000 ]---
> [    1.562178] EINJ: ACPI disabled.
>
> and after a bit:
>
> [    3.280015] Unable to handle kernel NULL pointer dereference at virtual address 0000000000000000
> [    3.280034] Mem abort info:
> [    3.280037]   ESR = 0x0000000086000004
> [    3.280041]   EC = 0x21: IABT (current EL), IL = 32 bits
> [    3.280048]   SET = 0, FnV = 0
> [    3.280052]   EA = 0, S1PTW = 0
> [    3.280056]   FSC = 0x04: level 0 translation fault
> [    3.280061] [0000000000000000] user address but active_mm is swapper
> [    3.280069] Internal error: Oops: 86000004 [#1] PREEMPT SMP
> [    3.280077] Modules linked in:
> [    3.280092] CPU: 0 PID: 9 Comm: kworker/u8:0 Tainted: G        W          6.0.0-rc6-00220-gb82580766e4c #147
> [    3.280103] Hardware name: Rockchip PX30 EVB (DT)
> [    3.280111] Workqueue: events_unbound async_run_entry_fn
> [    3.280140] pstate: 00000005 (nzcv daif -PAN -UAO -TCO -DIT -SSBS BTYPE=--)
> [    3.280150] pc : 0x0
> [    3.280160] lr : call_timer_fn.isra.30+0x24/0x80
> [    3.280171] sp : ffff80000a62b470
> [    3.280175] x29: ffff80000a62b470 x28: 0000000000000010 x27: 0000000000000004
> [    3.280190] x26: 0000000000000000 x25: 0000000000000000 x24: dead000000000122
> [    3.280204] x23: ffff800009a03000 x22: ffff80000a1d7000 x21: 0000000000000000
> [    3.280219] x20: 0000000000000101 x19: ffff000002d78000 x18: ffffffffffffffff
> [    3.280234] x17: ffff800075f19000 x16: ffff800008004000 x15: 00009726b6a67ac4
> [    3.280248] x14: 00000000000000c4 x13: 00000000000000c4 x12: ffff00007fb58d40
> [    3.280262] x11: 4200000000000000 x10: ffff00007fb52070 x9 : 0000000000000001
> [    3.280276] x8 : 0000000000000000 x7 : ffffffffffffffff x6 : 0000000000000000
> [    3.280290] x5 : 0000000000000000 x4 : 0000000000000000 x3 : 0000000000000200
> [    3.280303] x2 : 000000003fffffff x1 : 0000000000000000 x0 : ffff00000366fb10
> [    3.280318] Call trace:
> [    3.280322]  0x0
> [    3.280329]  run_timer_softirq+0x3c0/0x408
> [    3.280339]  __do_softirq+0x11c/0x288
> [    3.280348]  irq_exit_rcu+0xe8/0x108
> [    3.280361]  el1_interrupt+0x3c/0x70
> [    3.280374]  el1h_64_irq_handler+0x18/0x28
> [    3.280384]  el1h_64_irq+0x64/0x68
> [    3.280391]  console_emit_next_record.constprop.47+0x1a8/0x2c8
> [    3.280404]  console_unlock+0x1a0/0x1e0
> [    3.280414]  vprintk_emit+0x1c4/0x2d0
> [    3.280423]  dev_vprintk_emit+0x148/0x178
> [    3.280431]  dev_printk_emit+0x64/0x88
> [    3.280439]  __dev_printk+0x5c/0x7c
> [    3.280447]  _dev_info+0x6c/0x90
> [    3.280455]  dw_mci_setup_bus+0x114/0x218
> [    3.280467]  dw_mci_set_ios+0x12c/0x270
> [    3.280475]  mmc_power_up.part.21+0xa4/0xf8
> [    3.280486]  mmc_start_host+0xac/0xb8
> [    3.280494]  mmc_add_host+0x7c/0xe8
> [    3.280503]  dw_mci_probe+0x970/0xfc8
> [    3.280511]  dw_mci_pltfm_register+0xa0/0xd8
> [    3.280520]  dw_mci_rockchip_probe+0x84/0x148
> [    3.280530]  platform_probe+0x68/0xe0
> [    3.280544]  really_probe+0xc0/0x2b8
> [    3.280552]  __driver_probe_device+0x7c/0xe8
> [    3.280561]  driver_probe_device+0x38/0x100
> [    3.280570]  __driver_attach_async_helper+0x30/0x58
> [    3.280579]  async_run_entry_fn+0x30/0xd8
> [    3.280590]  process_one_work+0x1fc/0x350
> [    3.280601]  worker_thread+0x44/0x440
> [    3.280609]  kthread+0x10c/0x118
> [    3.280617]  ret_from_fork+0x10/0x20
> [    3.280639] Code: bad PC value
> [    3.280652] ---[ end trace 0000000000000000 ]---
> [    3.280661] Kernel panic - not syncing: Oops: Fatal exception in interrupt
> [    3.280667] SMP: stopping secondary CPUs
> [    3.280747] Kernel Offset: disabled
> [    3.280750] CPU features: 0x0000,00000020,00001086
> [    3.280758] Memory Limit: none
> [    3.696667] ---[ end Kernel panic - not syncing: Oops: Fatal exception in interrupt ]---
>
> I'm missing something? Let me know.
> Thanks in advance.

I had a similar issue on Rockchip 3399 [1], maybe it is related to your case?

[1] https://lore.kernel.org/linux-phy/6779635c-a162-0b7e-d124-d88d1ed9e162@sholland.org/

>
> Regards,
> Tommaso


--
Best regards,
Mikhail Rudenko



More information about the Linux-rockchip mailing list