Hi Marc, On Tue, Feb 19, 2019 at 05:54:43PM +0100, Marc Gonzalez wrote: > Hello, > > Next up: PCIe > > WIP changes on top of next-20190213: I assume this is basically a bug report and some debugging info? It doesn't have a changelog or signed-off-by (and doesn't touch anything in drivers/pci/) so I assume you're not expecting this to be merged? > diff --git a/arch/arm64/boot/dts/qcom/msm8998.dtsi b/arch/arm64/boot/dts/qcom/msm8998.dtsi > index f9a922fdae75..1152d11f081e 100644 > --- a/arch/arm64/boot/dts/qcom/msm8998.dtsi > +++ b/arch/arm64/boot/dts/qcom/msm8998.dtsi > @@ -970,6 +970,80 @@ > }; > }; > > + phy@1c06000 { > + compatible = "qcom,msm8996-qmp-pcie-phy"; > + reg = <0x1c06000 0x1000>; > + #clock-cells = <1>; > + #address-cells = <1>; > + #size-cells = <1>; > + ranges; > + > + clocks = <&gcc GCC_PCIE_PHY_AUX_CLK>, > + <&gcc GCC_PCIE_0_CFG_AHB_CLK>, > + <&gcc GCC_PCIE_CLKREF_CLK>; > + clock-names = "aux", "cfg_ahb", "ref"; > + > + vdda-phy-supply = <&vreg_l1a_0p875>; > + vdda-pll-supply = <&vreg_l2a_1p2>; > + > + resets = <&gcc GCC_PCIE_PHY_BCR>, > + <&gcc GCC_PCIE_PHY_COM_BCR>, > + <&gcc GCC_PCIE_PHY_NOCSR_COM_PHY_BCR>; > + reset-names = "phy", "common", "cfg"; > + > + pciephy: lane@35000 { > + reg = <0x1c07000 0x200>, <0x1c07200 0x200>, <0x1c07400 0x200>; > + #phy-cells = <0>; > + > + clock-output-names = "pcie_0_pipe_clk_src"; > + clocks = <&gcc GCC_PCIE_0_PIPE_CLK>; > + clock-names = "pipe0"; > + resets = <&gcc GCC_PCIE_0_PHY_BCR>; > + reset-names = "lane0"; > + }; > + }; > + > + pcie0: pci@1b000000 { > + compatible = "qcom,pcie-msm8996"; > + reg = <0x1b000000 0xf1d>, > + <0x1b000f20 0xa8>, > + <0x1c00000 0x2000>, > + <0x1b100000 0x100000>; > + reg-names = "dbi", "elbi", "parf", "config"; > + device_type = "pci"; > + linux,pci-domain = <0>; > + bus-range = <0x00 0xff>; > + num-lanes = <1>; > + #address-cells = <3>; > + #size-cells = <2>; > + power-domains = <&gcc PCIE_0_GDSC>; > + > + phys = <&pciephy>; > + phy-names = "pciephy"; > + > + ranges = > + /*** downstream I/O ***/ > + <0x01000000 0x0 0x1b200000 0x1b200000 0x0 0x100000>, > + /*** non-prefetchable memory ***/ > + <0x02000000 0x0 0x1b300000 0x1b300000 0x0 0xd00000>; > + > + interrupts = <GIC_SPI 405 IRQ_TYPE_LEVEL_HIGH>; > + interrupt-names = "msi"; > + #interrupt-cells = <1>; > + interrupt-map-mask = <0 0 0 0x7>; > + interrupt-map = <0 0 0 1 &intc 0 135 IRQ_TYPE_LEVEL_HIGH>, /* int_a */ > + <0 0 0 2 &intc 0 136 IRQ_TYPE_LEVEL_HIGH>, /* int_b */ > + <0 0 0 3 &intc 0 138 IRQ_TYPE_LEVEL_HIGH>, /* int_c */ > + <0 0 0 4 &intc 0 139 IRQ_TYPE_LEVEL_HIGH>; /* int_d */ > + > + clocks = <&gcc GCC_PCIE_0_PIPE_CLK>, > + <&gcc GCC_PCIE_0_MSTR_AXI_CLK>, > + <&gcc GCC_PCIE_0_SLV_AXI_CLK>, > + <&gcc GCC_PCIE_0_CFG_AHB_CLK>, > + <&gcc GCC_PCIE_0_AUX_CLK>; > + clock-names = "pipe", "bus_master", "bus_slave", "cfg", "aux"; > + }; > + > intc: interrupt-controller@17a00000 { > compatible = "arm,gic-v3"; > reg = <0x17a00000 0x10000>, /* GICD */ > diff --git a/drivers/clk/qcom/gcc-msm8998.c b/drivers/clk/qcom/gcc-msm8998.c > index 3cbabbb8bd9a..cdd97c840b07 100644 > --- a/drivers/clk/qcom/gcc-msm8998.c > +++ b/drivers/clk/qcom/gcc-msm8998.c > @@ -2161,7 +2161,7 @@ static struct clk_branch gcc_pcie_0_mstr_axi_clk = { > > static struct clk_branch gcc_pcie_0_pipe_clk = { > .halt_reg = 0x6b018, > - .halt_check = BRANCH_HALT, > + .halt_check = BRANCH_HALT_SKIP, > .clkr = { > .enable_reg = 0x6b018, > .enable_mask = BIT(0), > > > > > > Current situation: HANG + REBOOT :-) > Probably some silly typo in an address in my DT. Investigating... > > # modprobe phy-qcom-qmp > REMAP: PA=0c010000 VA=ffffff8010005000 SIZE=18c > REMAP: PA=0c010200 VA=ffffff801000d200 SIZE=128 > REMAP: PA=0c010400 VA=ffffff801002d400 SIZE=200 > REMAP: PA=0c010c00 VA=ffffff8010035c00 SIZE=20c > REMAP: PA=0c010600 VA=ffffff8010051600 SIZE=128 > REMAP: PA=0c010800 VA=ffffff8010053800 SIZE=200 > qcom-qmp-phy c010000.phy: PHY pcs_misc-reg not used > qcom-qmp-phy c010000.phy: Registered Qcom-QMP phy > [ CLK_BASE + 6b004] = 00282000 > REMAP: PA=01c00000 VA=ffffff8010b72000 SIZE=2000 > REMAP: PA=01c06000 VA=ffffff8010055000 SIZE=1000 > REMAP: PA=1b000000 VA=ffffff801005d000 SIZE=f1d > REMAP: PA=01c07000 VA=ffffff8010065000 SIZE=200 > REMAP: PA=1b000f20 VA=ffffff801006df20 SIZE=a8 > REMAP: PA=01c07200 VA=ffffff8010075200 SIZE=200 > [ CLK_BASE + 6b004] = a0282001 > REMAP: PA=01c07400 VA=ffffff801007d400 SIZE=200 > qcom-qmp-phy 1c06000.phy: PHY pcs_misc-reg not used > qcom-qmp-phy 1c06000.phy: Registered Qcom-QMP phy > [ CLK_BASE + 6b004] = 00282000 > REMAP: PA=01c00000 VA=ffffff8010d02000 SIZE=2000 > REMAP: PA=1b000000 VA=ffffff801005d000 SIZE=f1d > REMAP: PA=1b000f20 VA=ffffff801006df20 SIZE=a8 > qcom-pcie 1b000000.pci: 1b000000.pci supply vdda not found, using dummy regulator > qcom-pcie 1b000000.pci: 1b000000.pci supply vddpe-3v3 not found, using dummy regulator > qcom-qmp-phy 1c06000.phy: Initializing QMP phy > [ CLK_BASE + 6f000] = 00000001 > [ CLK_BASE + 6f014] = 00000001 > [ CLK_BASE + 6f00c] = 00000001 > [ CLK_BASE + 6f00c] = 00000000 > [ CLK_BASE + 6f014] = 00000000 > [ CLK_BASE + 6f000] = 00000000 > [ CLK_BASE + 6f004] = 80000001 > [ CLK_BASE + 6b010] = 80008001 > [ CLK_BASE + 8800c] = 80000001 > [ PCIE_DBI + 00404] = 0000000b > [ PCIE_DBI + 00034] = 0000001c > [ PCIE_DBI + 00038] = 00000010 > [ PCIE_DBI + 00174] = 00000033 > [ PCIE_DBI + 00194] = 00000006 > [ PCIE_DBI + 000c8] = 00000042 > [ PCIE_DBI + 00128] = 00000000 > [ PCIE_DBI + 00144] = 000000ff > [ PCIE_DBI + 00148] = 0000001f > [ PCIE_DBI + 00178] = 00000001 > [ PCIE_DBI + 0019c] = 00000001 > [ PCIE_DBI + 0018c] = 00000000 > [ PCIE_DBI + 00184] = 0000000a > [ PCIE_DBI + 0000c] = 00000009 > [ PCIE_DBI + 000d0] = 00000082 > [ PCIE_DBI + 000e4] = 00000003 > [ PCIE_DBI + 000e0] = 00000055 > [ PCIE_DBI + 000dc] = 00000055 > [ PCIE_DBI + 00054] = 00000000 > [ PCIE_DBI + 00050] = 0000001a > [ PCIE_DBI + 0004c] = 0000000a > [ PCIE_DBI + 00174] = 00000033 > [ PCIE_DBI + 0003c] = 00000002 > [ PCIE_DBI + 00040] = 0000001f > [ PCIE_DBI + 000ac] = 00000004 > [ PCIE_DBI + 00078] = 0000000b > [ PCIE_DBI + 00084] = 00000016 > [ PCIE_DBI + 00090] = 00000028 > [ PCIE_DBI + 0010c] = 00000000 > [ PCIE_DBI + 00108] = 00000080 > [ PCIE_DBI + 00010] = 00000001 > [ PCIE_DBI + 0001c] = 00000031 > [ PCIE_DBI + 00020] = 00000001 > [ PCIE_DBI + 00014] = 00000002 > [ PCIE_DBI + 00018] = 00000000 > [ PCIE_DBI + 00024] = 0000002f > [ PCIE_DBI + 00028] = 00000019 > [ PCIE_DBI + 000c4] = 00000015 > [ PCIE_DBI + 00070] = 0000000f > [ PCIE_DBI + 00048] = 0000000f > [ PCIE_DBI + 00074] = 00000019 > [ PCIE_DBI + 00038] = 00000010 > [ PCIE_DBI + 00178] = 00000000 > [ PCIE_DBI + 000c4] = 00000040 > [ PCIE_DBI + 00400] = 0000000a > [ PCIE_DBI + 00408] = 0000000b > [ CLK_BASE + 6b018] = 80004001 > [ PCIE_DBI + 00068] = 00000045 > [ PCIE_DBI + 00094] = 00000006 > [ 01c07200 + 00110] = 0000001c > [ 01c07200 + 000d8] = 00000001 > [ 01c07200 + 000dc] = 00000000 > [ 01c07200 + 000e0] = 000000db > [ 01c07200 + 00120] = 00000018 > [ 01c07200 + 0001c] = 00000004 > [ 01c07200 + 00010] = 00000004 > [ 01c07200 + 00048] = 0000004b > [ 01c07200 + 0011c] = 00000014 > [ 01c07200 + 00118] = 00000019 > [ 01c07400 + 00058] = 0000004c > [ 01c07400 + 000a0] = 00000000 > [ 01c07400 + 000a4] = 00000001 > [ 01c07400 + 000a8] = 00000005 > [ 01c07400 + 00054] = 00000005 > [ 01c07400 + 00004] = 00000002 > [ 01c07400 + 0006c] = 00000000 > [ 01c07400 + 00060] = 000000a3 > [ 01c07400 + 00028] = 0000000e > [ 01c07400 + 00004] = 00000003 > [ 01c07400 + 00000] = 00000000 > [ 01c07400 + 00008] = 0000000a > qcom-pcie 1b000000.pci: host bridge /soc/pci@1b000000 ranges: > qcom-pcie 1b000000.pci: Parsing ranges property... > qcom-pcie 1b000000.pci: IO 0x1b200000..0x1b2fffff -> 0x1b200000 > qcom-pcie 1b000000.pci: MEM 0x1b300000..0x1bffffff -> 0x1b300000 > REMAP: PA=1b100000 VA=ffffff8011400000 SIZE=80000 > REMAP: PA=1b180000 VA=ffffff8011500000 SIZE=80000 > [ CLK_BASE + 6b014] = 80000001 > [ CLK_BASE + 6b00c] = 80004221 > [ CLK_BASE + 6b008] = 8000c221 > [ PCIE_PARF + 00040] = 00000000 > [ PCIE_PARF + 00168] = 00000000 > [ PCIE_PARF + 00000] = 00000000 > [ PCIE_PARF + 00174] = 00000010 > [ PCIE_PARF + 001a8] = 80000000 > dw_pcie_read: addr=ffffff801005d710 size=4 > Internal error: synchronous external abort: 96000210 [#1] PREEMPT SMP > Modules linked in: phy_qcom_qmp > CPU: 2 PID: 101 Comm: kworker/2:1 Tainted: G S 5.0.0-rc6-next-20190213 #13 > Hardware name: Qualcomm Technologies, Inc. MSM8998 v1 MTP (DT) > Workqueue: events deferred_probe_work_func > pstate: 60000005 (nZCv daif -PAN -UAO) > pc : dw_pcie_read+0x90/0x110 > lr : dw_pcie_read+0x38/0x110 > sp : ffffff801120ba10 > x29: ffffff801120ba10 x28: 0000000000000000 > x27: ffffffc098ab9d80 x26: ffffffc0a5cd46b8 > x25: ffffffc0a5cd46b8 x24: ffffff8010a18000 > x23: ffffffc0a5cd4400 x22: 0000000000000000 > x21: ffffff801120ba64 x20: 0000000000000004 > x19: ffffff801005d710 x18: ffffffffffffffff > x17: 0000000000000000 x16: 0000000000000000 > x15: ffffff8010a18508 x14: 0720072007200720 > x13: 0720072007200720 x12: 0720072007200720 > x11: 0720072007200720 x10: 0720072007200720 > x9 : 0720072007200720 x8 : 000000000000017b > x7 : 0720072007200720 x6 : ffffffc0f843bf00 > x5 : 0000000000000000 x4 : 0000000000000000 > x3 : 0000000000000001 x2 : d73a0bc4b3dd9300 > x1 : 0000000000000000 x0 : 0000000000000003 > Process kworker/2:1 (pid: 101, stack limit = 0x(____ptrval____)) > Call trace: > dw_pcie_read+0x90/0x110 > __dw_pcie_read_dbi+0x70/0xa0 > dw_pcie_setup+0x60/0x160 > dw_pcie_setup_rc+0x38/0x360 > qcom_pcie_host_init+0xbc/0x160 > dw_pcie_host_init+0x248/0x510 > qcom_pcie_probe+0x20c/0x250 > platform_drv_probe+0x50/0xa0 > really_probe+0x20c/0x2c0 > driver_probe_device+0x58/0x100 > __device_attach_driver+0x90/0xd0 > bus_for_each_drv+0x64/0xd0 > __device_attach+0xd8/0x140 > device_initial_probe+0x10/0x20 > bus_probe_device+0x90/0xa0 > deferred_probe_work_func+0x74/0xb0 > process_one_work+0x1e0/0x320 > worker_thread+0x40/0x450 > kthread+0x118/0x120 > ret_from_fork+0x10/0x20 > Code: a94153f3 f94013f5 a8c37bfd d65f03c0 (b9400273) > ---[ end trace f9304c55055774a4 ]--- > rcu: INFO: rcu_preempt detected stalls on CPUs/tasks: > rcu: (detected by 3, t=5252 jiffies, g=-567, q=4) > rcu: All QSes seen, last rcu_preempt kthread activity 5236 (4294903741-4294898505), jiffies_till_next_fqs=1, root ->qsmask 0x0 > swapper/3 R running task 0 0 1 0x00000008 > Call trace: > dump_backtrace+0x0/0x150 > show_stack+0x14/0x20 > sched_show_task+0x104/0x140 > rcu_sched_clock_irq+0x8c0/0x930 > update_process_times+0x2c/0x60 > tick_sched_handle.isra.5+0x30/0x50 > tick_sched_timer+0x54/0xb0 > __hrtimer_run_queues+0x120/0x1c0 > hrtimer_interrupt+0xdc/0x250 > arch_timer_handler_virt+0x28/0x40 > handle_percpu_devid_irq+0x94/0x150 > generic_handle_irq+0x24/0x40 > __handle_domain_irq+0x84/0xf0 > gic_handle_irq+0x90/0x1ac > el1_irq+0xb8/0x180 > arch_cpu_idle+0x1c/0x30 > default_idle_call+0x1c/0x38 > do_idle+0xc4/0x160 > cpu_startup_entry+0x20/0x30 > secondary_start_kernel+0x178/0x1c0 > rcu: rcu_preempt kthread starved for 5236 jiffies! g-567 f0x2 RCU_GP_WAIT_FQS(5) ->state=0x200 ->cpu=1 > rcu: RCU grace-period kthread stack dump: > rcu_preempt R 0 10 2 0x00000008 > Call trace: > __switch_to+0x174/0x1e0 > __schedule+0x1cc/0x4c0 > schedule+0x2c/0x80 > schedule_timeout+0x8c/0x3a0 > rcu_gp_kthread+0x4b4/0x840 > kthread+0x118/0x120 > ret_from_fork+0x10/0x20