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

Tommaso Merciai tommaso.merciai at amarulasolutions.com
Fri Sep 23 08:20:00 PDT 2022


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.

Regards,
Tommaso


-- 
Tommaso Merciai
Embedded Linux Engineer
tommaso.merciai at amarulasolutions.com
__________________________________

Amarula Solutions SRL
Via Le Canevare 30, 31100 Treviso, Veneto, IT
T. +39 042 243 5310
info at amarulasolutions.com
www.amarulasolutions.com



More information about the Linux-rockchip mailing list