On 12.10.2023 19:21, Manivannan Sadhasivam wrote: > UFS host controller, when scaling gears, should choose appropriate > performance state of RPMh power domain controller along with clock > frequency. So let's add the OPP table support to specify both clock > frequency and RPMh performance states replacing the old "freq-table-hz" > property. > > Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@xxxxxxxxxx> > Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@xxxxxxxxxx> > --- This patch landed in today's linux-next as commit 725be1d6318e ("arm64: dts: qcom: sm8250: Add OPP table support to UFSHC"). Unfortunately it breaks booting of my RB5 board with the following messages: ufshcd-qcom 1d84000.ufshc: Adding to iommu group 5 ufshcd-qcom 1d84000.ufshc: freq-table-hz property not specified ufshcd-qcom 1d84000.ufshc: ufshcd_populate_vreg: Unable to find vdd-hba-supply regulator, assuming enabled ufshcd-qcom 1d84000.ufshc: freq-table-hz property not specified ufshcd-qcom 1d84000.ufshc: ufshcd_populate_vreg: Unable to find vdd-hba-supply regulator, assuming enabled scsi host0: ufshcd ufshcd-qcom 1d84000.ufshc: UNIPRO clk freq 0 MHz not supported ufshcd-qcom 1d84000.ufshc: cfg core clk ctrl failed clk: Disabling unused clocks ALSA device list: No soundcards found. Waiting 2 sec before mounting root device... ufshcd-qcom 1d84000.ufshc: uic cmd 0x16 with arg3 0x0 completion timeout ufshcd-qcom 1d84000.ufshc: Controller enable failed ufshcd-qcom 1d84000.ufshc: Controller enable failed ufshcd-qcom 1d84000.ufshc: Controller enable failed ufshcd-qcom 1d84000.ufshc: Controller enable failed ufshcd-qcom 1d84000.ufshc: link startup failed -110 ufshcd-qcom 1d84000.ufshc: UFS Host state=0 ufshcd-qcom 1d84000.ufshc: outstanding reqs=0x0 tasks=0x0 ufshcd-qcom 1d84000.ufshc: saved_err=0x0, saved_uic_err=0x0 ufshcd-qcom 1d84000.ufshc: Device power mode=1, UIC link state=0 ufshcd-qcom 1d84000.ufshc: PM in progress=0, sys. suspended=0 ufshcd-qcom 1d84000.ufshc: Auto BKOPS=0, Host self-block=0 ufshcd-qcom 1d84000.ufshc: Clk gate=1 ufshcd-qcom 1d84000.ufshc: last_hibern8_exit_tstamp at 0 us, hibern8_exit_cnt=0 ufshcd-qcom 1d84000.ufshc: last intr at 2889168 us, last intr status=0x400 ufshcd-qcom 1d84000.ufshc: error handling flags=0x0, req. abort count=0 ufshcd-qcom 1d84000.ufshc: hba->ufs_version=0x300, Host capabilities=0x1587031f, caps=0x12cf ufshcd-qcom 1d84000.ufshc: quirks=0x80000, dev. quirks=0x0 host_regs: 00000000: 1587031f 00000000 00000300 00000000 host_regs: 00000010: 01000000 00010217 00000000 00000000 host_regs: 00000020: 00000000 00000000 00000000 00000000 host_regs: 00000030: 00000008 00000000 00000000 00000000 host_regs: 00000040: 00000000 00000000 00000000 00000000 host_regs: 00000050: 00000000 00000000 00000000 00000000 host_regs: 00000060: 00000000 00000000 00000000 00000000 host_regs: 00000070: 00000000 00000000 00000000 00000000 host_regs: 00000080: 00000000 00000000 00000000 00000000 host_regs: 00000090: 00000000 00000001 00000000 00000000 ufshcd-qcom 1d84000.ufshc: No record of pa_err ufshcd-qcom 1d84000.ufshc: No record of dl_err ufshcd-qcom 1d84000.ufshc: No record of nl_err ufshcd-qcom 1d84000.ufshc: No record of tl_err ufshcd-qcom 1d84000.ufshc: No record of dme_err ufshcd-qcom 1d84000.ufshc: No record of auto_hibern8_err ufshcd-qcom 1d84000.ufshc: No record of fatal_err ufshcd-qcom 1d84000.ufshc: link_startup_fail[0] = 0xffffff92 at 3663462 us ufshcd-qcom 1d84000.ufshc: link_startup_fail: total cnt=1 ufshcd-qcom 1d84000.ufshc: No record of resume_fail ufshcd-qcom 1d84000.ufshc: No record of suspend_fail ufshcd-qcom 1d84000.ufshc: No record of wlun resume_fail ufshcd-qcom 1d84000.ufshc: No record of wlun suspend_fail ufshcd-qcom 1d84000.ufshc: No record of dev_reset ufshcd-qcom 1d84000.ufshc: No record of host_reset ufshcd-qcom 1d84000.ufshc: No record of task_abort HCI Vendor Specific Registers 00000000: 0000012c 00000000 00000000 00000000 HCI Vendor Specific Registers 00000010: 00000042 00000000 00000001 1c00052c HCI Vendor Specific Registers 00000020: 3f011300 40020000 00000000 00000000 HCI Vendor Specific Registers 00000030: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000000: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000010: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000020: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000030: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000040: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000050: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000060: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000070: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000080: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 00000090: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_REG_OCSC 000000a0: 00000000 00000000 00000000 00000000 UFS_UFS_DBG_RD_EDTL_RAM 00000000: 00000000 7147f7fd 47857989 b7556f16 UFS_UFS_DBG_RD_EDTL_RAM 00000010: ad69b114 7cd5fd55 41d57796 0e55e717 UFS_UFS_DBG_RD_EDTL_RAM 00000020: 04558745 efc573b5 4f35f49b b2697d16 UFS_UFS_DBG_RD_EDTL_RAM 00000030: 5c7563d5 7755f4d6 cf65dd90 6591d535 UFS_UFS_DBG_RD_EDTL_RAM 00000040: 4151f597 ffaf75a9 57442485 f7654511 UFS_UFS_DBG_RD_EDTL_RAM 00000050: fc57e046 ff57f5b5 c7c53417 adb56f55 UFS_UFS_DBG_RD_EDTL_RAM 00000060: 9b753f4c 5155a115 245525f1 77755d51 UFS_UFS_DBG_RD_EDTL_RAM 00000070: 5791ffdf 77555756 7cd5b941 431ce192 UFS_UFS_DBG_RD_DESC_RAM 00000000: 7dfffedf 001fbffb ff7fffff 003ffffd UFS_UFS_DBG_RD_DESC_RAM 00000010: 7f3dfff5 003fffff 7ffdfff3 0017fff7 UFS_UFS_DBG_RD_DESC_RAM 00000020: 3fdd595f 003ff5b7 ffffdfdf 003f77f7 UFS_UFS_DBG_RD_DESC_RAM 00000030: fffff7d7 003f75f7 7fffffff 0037ffff UFS_UFS_DBG_RD_DESC_RAM 00000040: fdff7f7f 003f57df fdfeffbf 003ffff7 UFS_UFS_DBG_RD_DESC_RAM 00000050: 7d7d7fff 00379d7f 7ffd7fff 001f3fff UFS_UFS_DBG_RD_DESC_RAM 00000060: 7f7fdeff 003fffd5 f7f7fffd 003fffff UFS_UFS_DBG_RD_DESC_RAM 00000070: 777ffd7d 003ffd75 ff7ffffd 003f7ffd UFS_UFS_DBG_RD_DESC_RAM 00000080: ff15fddf 003edfd7 df5ffff7 003fffdf UFS_UFS_DBG_RD_DESC_RAM 00000090: ffe57f5f 003fbff7 ddd7ff75 003f7fff UFS_UFS_DBG_RD_DESC_RAM 000000a0: fd4ffffd 003dddff eefffff7 003fbfff UFS_UFS_DBG_RD_DESC_RAM 000000b0: 67fffffd 001ff7fd bdd75f7f 0031bfff UFS_UFS_DBG_RD_DESC_RAM 000000c0: ffdddf75 003fff5d 7f5fffdd 002f7fdf UFS_UFS_DBG_RD_DESC_RAM 000000d0: ff7d5ffd 0037fdff df675fd5 001ffbdf UFS_UFS_DBG_RD_DESC_RAM 000000e0: b5ff7dff 00337ffc ff7ff7fb 003ffff7 UFS_UFS_DBG_RD_DESC_RAM 000000f0: 5ffdffdd 001ddfff 75ffddff 003fffff UFS_UFS_DBG_RD_DESC_RAM 00000100: ff5f5fdf 003d37bf ff77dfff 0017edb7 UFS_UFS_DBG_RD_DESC_RAM 00000110: ff7ff7ff 003ffd7f ff5f7fdd 003f3fd7 UFS_UFS_DBG_RD_DESC_RAM 00000120: 7fffffdf 003ff5d9 55ffffdf 003f79d5 UFS_UFS_DBG_RD_DESC_RAM 00000130: d5ffe7f5 002767fe ffdd75df 003d7fdf UFS_UFS_DBG_RD_DESC_RAM 00000140: 7fff77ff 003dff5f 7d7ff7ff 002f7fff UFS_UFS_DBG_RD_DESC_RAM 00000150: fdff7ddf 003fe7dd 5df77ddd 0037f7ff UFS_UFS_DBG_RD_DESC_RAM 00000160: f7f16977 003f9fdf 5775ff77 00357ff5 UFS_UFS_DBG_RD_DESC_RAM 00000170: 7ffdfffb 003dff5f 7f7f77f7 003fffff UFS_UFS_DBG_RD_DESC_RAM 00000180: 57dff7df 003dffff fffdd7ff 001efffd UFS_UFS_DBG_RD_DESC_RAM 00000190: 7dffffed 003f7fce 77d9f7ff 001fdddd UFS_UFS_DBG_RD_DESC_RAM 000001a0: ddffdffd 001fd57d 7f7ff777 003f78dd UFS_UFS_DBG_RD_DESC_RAM 000001b0: d5eff77f 0037dfdf ed7d77ff 003ffffd UFS_UFS_DBG_RD_DESC_RAM 000001c0: cf7fdfff 001f5f7e ffffffff 003f57df UFS_UFS_DBG_RD_DESC_RAM 000001d0: fdfffffd 003f7dff 556ffddf 003fdd7f UFS_UFS_DBG_RD_DESC_RAM 000001e0: fdff71df 003e7fff ff3f7fd7 0037f77b UFS_UFS_DBG_RD_DESC_RAM 000001f0: 7f7f7677 00355fdf 7feffdff 0037ffff UFS_UFS_DBG_RD_PRDT_RAM 00000000: d1700001 0000192c 3d9edf71 00075d51 UFS_UFS_DBG_RD_PRDT_RAM 00000010: 4561073f 0000415d ddde6dd9 000ff55f UFS_UFS_DBG_RD_PRDT_RAM 00000020: adb7185f 000df971 579caffd 000de54d UFS_UFS_DBG_RD_PRDT_RAM 00000030: 45e55747 00057559 7f5e5dbd 000377df UFS_UFS_DBG_RD_PRDT_RAM 00000040: dd175467 0007dc9c 4e775d77 0007555f UFS_UFS_DBG_RD_PRDT_RAM 00000050: 1f15dd77 000d195d f1c9e535 0007b75f UFS_UFS_DBG_RD_PRDT_RAM 00000060: 15bd75f3 0007675f dfd59d77 00057b5c UFS_UFS_DBG_RD_PRDT_RAM 00000070: d4f09dee 00017d39 52857d56 000c6ddd UFS_UFS_DBG_RD_PRDT_RAM 00000080: c333fcd6 000545df 1d57f51d 000577e9 UFS_UFS_DBG_RD_PRDT_RAM 00000090: 9f83d45d 00055d18 d4e7d7ee 000713df UFS_UFS_DBG_RD_PRDT_RAM 000000a0: fdfe39d7 000754df d54f5d77 000746f1 UFS_UFS_DBG_RD_PRDT_RAM 000000b0: 5a40c5f5 000c45d4 17471fe3 000e9d1d UFS_UFS_DBG_RD_PRDT_RAM 000000c0: 1747dd5f 00074577 d540d75d 00044d67 UFS_UFS_DBG_RD_PRDT_RAM 000000d0: de3545d3 000c4757 5f845115 00063795 UFS_UFS_DBG_RD_PRDT_RAM 000000e0: d15d776c 000c7fd5 1f5f5d75 00067d75 UFS_UFS_DBG_RD_PRDT_RAM 000000f0: d71d4c7d 0007bd13 7557d77d 000355df UFS_DBG_RD_REG_UAWM 00000000: 00000000 0fe00000 00000004 f4000102 UFS_DBG_RD_REG_UARM 00000000: 00000000 00000000 00000001 00000001 UFS_DBG_RD_REG_TXUC 00000000: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000010: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000020: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000030: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000040: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000050: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000060: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000070: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000080: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 00000090: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 000000a0: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TXUC 000000b0: 00000001 00000000 00000000 00000004 UFS_DBG_RD_REG_RXUC 00000000: 00000000 00000000 00000000 00000004 UFS_DBG_RD_REG_RXUC 00000010: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_RXUC 00000020: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_RXUC 00000030: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_RXUC 00000040: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_RXUC 00000050: 00000000 00000000 00000000 00000001 UFS_DBG_RD_REG_RXUC 00000060: 00000000 00000000 00000004 UFS_DBG_RD_REG_DFC 00000000: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_DFC 00000010: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_DFC 00000020: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_DFC 00000030: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_DFC 00000040: ffffffff 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000000: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000010: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000020: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000030: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000040: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000050: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000060: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000070: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TRLUT 00000080: 00000000 00000000 UFS_DBG_RD_REG_TMRLUT 00000000: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TMRLUT 00000010: 00000000 00000000 00000000 00000000 UFS_DBG_RD_REG_TMRLUT 00000020: 00000000 ------------[ cut here ]------------ gcc_ufs_phy_axi_clk status stuck at 'off' WARNING: CPU: 3 PID: 103 at drivers/clk/qcom/clk-branch.c:86 clk_branch_wait+0x144/0x15c Modules linked in: CPU: 3 PID: 103 Comm: kworker/u17:0 Not tainted 6.7.0-rc4-next-20231205 #14278 Hardware name: Qualcomm Technologies, Inc. Robotics RB5 (DT) Workqueue: ufs_clk_gating_0 ufshcd_ungate_work pstate: 604000c5 (nZCv daIF +PAN -UAO -TCO -DIT -SSBS BTYPE=--) pc : clk_branch_wait+0x144/0x15c lr : clk_branch_wait+0x144/0x15c sp : ffff80008160bc20 x29: ffff80008160bc20 x28: ffffa967de7ea200 x27: 0000000000000000 x26: ffff03ffc7bb18e8 x25: 0000000112be0f33 x24: 0000000000000001 x23: ffffa967dd981888 x22: 0000000000000001 x21: ffffa967dc27166c x20: 0000000000000000 x19: ffffa967deae9920 x18: 0000000000000038 x17: 0000000000000000 x16: 0000000000003ff1 x15: fffffffffffe9c68 x14: ffffa967de815360 x13: 0000000000000669 x12: 0000000000000223 x11: fffffffffffe9c68 x10: fffffffffffe9c30 x9 : 00000000fffff223 x8 : ffffa967de815360 x7 : ffffa967de86d360 x6 : 00000000000019a4 x5 : 000000000000bff4 x4 : 00000000fffff223 x3 : 0000000000000000 x2 : 0000000000000000 x1 : 0000000000000000 x0 : ffff03ffc7266500 Call trace: clk_branch_wait+0x144/0x15c clk_branch2_enable+0x30/0x40 clk_core_enable+0xe8/0x284 clk_enable+0x2c/0x4c ufshcd_setup_clocks+0x268/0x3d4 ufshcd_ungate_work+0xc0/0x134 process_one_work+0x1ec/0x53c worker_thread+0x298/0x408 kthread+0x124/0x128 ret_from_fork+0x10/0x20 irq event stamp: 76 hardirqs last enabled at (75): [<ffffa967dcc9ced0>] _raw_spin_unlock_irq+0x30/0x6c hardirqs last disabled at (76): [<ffffa967dc224250>] clk_enable_lock+0x7c/0xf0 softirqs last enabled at (0): [<ffffa967dbb186c8>] copy_process+0x650/0x21d8 softirqs last disabled at (0): [<0000000000000000>] 0x0 ---[ end trace 0000000000000000 ]--- ufshcd-qcom 1d84000.ufshc: ufshcd_setup_clocks: core_clk prepare enable failed, -16 Let me know if you need more logs or information. > arch/arm64/boot/dts/qcom/sm8250.dtsi | 39 +++++++++++++++++++++------- > 1 file changed, 30 insertions(+), 9 deletions(-) > > diff --git a/arch/arm64/boot/dts/qcom/sm8250.dtsi b/arch/arm64/boot/dts/qcom/sm8250.dtsi > index a4e58ad731c3..33abd84aae53 100644 > --- a/arch/arm64/boot/dts/qcom/sm8250.dtsi > +++ b/arch/arm64/boot/dts/qcom/sm8250.dtsi > @@ -2198,21 +2198,42 @@ ufs_mem_hc: ufshc@1d84000 { > <&gcc GCC_UFS_PHY_TX_SYMBOL_0_CLK>, > <&gcc GCC_UFS_PHY_RX_SYMBOL_0_CLK>, > <&gcc GCC_UFS_PHY_RX_SYMBOL_1_CLK>; > - freq-table-hz = > - <37500000 300000000>, > - <0 0>, > - <0 0>, > - <37500000 300000000>, > - <0 0>, > - <0 0>, > - <0 0>, > - <0 0>; > + > + operating-points-v2 = <&ufs_opp_table>; > > interconnects = <&aggre1_noc MASTER_UFS_MEM 0 &mc_virt SLAVE_EBI_CH0 0>, > <&gem_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_UFS_MEM_CFG 0>; > interconnect-names = "ufs-ddr", "cpu-ufs"; > > status = "disabled"; > + > + ufs_opp_table: opp-table { > + compatible = "operating-points-v2"; > + > + opp-37500000 { > + opp-hz = /bits/ 64 <37500000>, > + /bits/ 64 <0>, > + /bits/ 64 <0>, > + /bits/ 64 <37500000>, > + /bits/ 64 <0>, > + /bits/ 64 <0>, > + /bits/ 64 <0>, > + /bits/ 64 <0>; > + required-opps = <&rpmhpd_opp_low_svs>; > + }; > + > + opp-300000000 { > + opp-hz = /bits/ 64 <300000000>, > + /bits/ 64 <0>, > + /bits/ 64 <0>, > + /bits/ 64 <300000000>, > + /bits/ 64 <0>, > + /bits/ 64 <0>, > + /bits/ 64 <0>, > + /bits/ 64 <0>; > + required-opps = <&rpmhpd_opp_nom>; > + }; > + }; > }; > > ufs_mem_phy: phy@1d87000 { Best regards -- Marek Szyprowski, PhD Samsung R&D Institute Poland